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Писать об устройствах типа ВетоиШ 
Вох, не упомянув при этом имени 
швейцарского ученого Даниила Бернулли, 
так же невозможно, как, рассказывая об 
истории авиации, не вспомнить братьев 
Райт. Хотя впрочем, если не к авиации, 
то к аэродинамике почетный член 
Петербургской Академии Наук 
Д. Бернулли имеет непосредственное 
отношение. 


Из истории ВегпоиШ 


Еще из курса средней школы 
известен закон течения идеальной 
жидкости или газа, описываемый 
уравнением Бернулли: давление 

на поверхность, создаваемое 
потоком движущейся жидкости 
или газа, зависит от скорости 
этого потока. Причем, чем 
быстрее движется газ (или 
жидкость), тем меньше давление 
на поверхность. Этот, на первый 
взгляд, достаточно скучный 
феномен уже давно имеет яркое 
практическое применение. Бла- 
годаря тому, что профиль несущей 
поверхности самолета выполнен 
определенным образом, скорость 
движения воздуха над верхней 
частью поверхности выше, чем 
под нижней. Результирующая 
разница давлений и обуславливает 
подъемную силу. 

Специалисты американской 
фирмы Іотева нашли красивое ре- 
шение для минимизации расстоя- 


ния между магнитным слоем носи- 
теля и головкой записи/считыва- 
ния, используя для регулирования 
этого расстояния известное соот- 
ношение Бернулли. Внешне новый 
носитель данных — ВегпоиШ 
СаПгібве — выглядит как увели- 
ченная до 5,25 дюймов обычная 

з, 5-дюймовая дискета. Движение 
воздуха в этой конструкции созда- 
ется благодаря быстрому враще- 
нию диска. Неподвижный диск с 
магнитным носителем прогибается 
под тяжестью собственного веса, 

и, поскольку он расположен ниже 
головки, отдаляется от нее. При 
выборе оптимальной скорости вра- 
щения магнитный слой носителя и 
головку разделяет крошечная про- 
слойка воздуха (три миллионных 
миллиметра). Головка “летит“ над 
рабочей поверхностью носителя и, 
как следствие, отсутствует ее из- 
нос. При снижении количества 
оборотов, например, из-за отклю- 


чения электропитания, расстояние 
между поверхностью магнитного 
носителя и универсальной голов- 
кой автоматически увеличивается. 

Рассматриваемые ниже накопи- 
тели, использующие эффект Бер- 
нулли (КетоѵаЫе Сагігібве Огіѵе, 
К.СО), представляют уже второе 
поколение подобных устройств, 
используя в качестве сменного но- 
сителя — картриджа — теперь 
уже 5,25-дюймовые кассеты, вме- 
сто прежних 8-дюймовых. Это мо- 
дели ВегпоиШ Вох II, ВегпоиШ 
202 и ВегпоиШ II 44. Версии этих 
устройств имеют как встроенное 
(іпіегпаі зиЬзузІет), так и вне- 
шнее исполнение (ехіегпаі $иЬ- 
зузіет). Первые две модели КСІ) 
позволяют использовать кар- 
триджи емкостью 20 Мбайт, по- 
следняя — 44 Мбайта. 

Некоторые характеристики этих 
устройств приведены на рис.1. 
Следует пояснить, что устройство 
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есть. Пассивное устройство 
управляется через кон- 
троллер активного. 

Драйвер КСО.ЗѴЗ, по- 
ставляемый фирмой Іошеда в 
составе программного обес- 
печения, позволяет использо- 
вать накопители с версией 
М3 ЭОЗ не ниже 3.0. Если 
Нозі-адаптер для КСО имеет 
тип РС2В/50, то имеется 
возможность выполнить за- 
грузку компьютера с систем- 
ного картриджа. Правда, 
здесь имеются и другие огра- 
ничения. Во-первых, извест- 
но, что Р08Т ВІ08 позволя- 
ет выполнять загрузку 003 
либо с устройства А:, либо с 
устройства С:, таким обра- 
зом, чтобы стартовать с 
КСО, необходимо (иногда 
даже физически) отключить 
имеющийся винчестер, вос- 
принимаемый обычно как 
устройство С:. Во-вторых, 
версии 008 ниже 4.0 под- 
держивают разделы жесткого 
ВегпоиШ 202 является Микропереключатели на плате диска размером не более 

улучшенным вариантом ВегпоиШ определяют область адресов адап- 32 Мбайт. И хотя драйвер 

Вох II, это касается как скорости тера для компьютера КСО.ЗѴЗ позволяет работать с 44- 

передачи данных, так и времени (340Н...375Н), номер используемо- Мбайтными картриджами под ран- 

выборки. Причем владельцы го канала прямого доступа к памя- ними версиями 003, для того, 

накопителей ВегпоиШ Вох II могут ти (ЭМА 1 или 3), способ вво- чтобы загрузиться с такой 

путем простой модернизации плат да/вывода данных (программный кассеты, необходимо разбить ее на 

улучшить рабочие характеристики или с использованием ОМА), ко- разделы в 32 Мбайта (загрузоч- 

накопителей до значений личество подсоединенных КСО ный) и 12 Мбайт (увы! никак уже 
параметров ВегпоиШ 202. (один или два). Перемычки на не используемый). Поскольку пять 

В комплект поставки, помимо плате устанавливают начальный утилит для МЗ-ООЗ заменены для 

одного или двух КСО, кабелей, адрес КОМ (в диапазоне Іотеда КСО собственными утили- 

документации и программ, входит С8000Ь...Е4000Ь), при этом воз- тами (рис.2.), форматирование 

плата Н озі-адаптера для компью- можно использовать одно из 15 картриджа или раздела произво- 

тера (например, ІВМ РС). Она различных значений в указанном дится утилитой КСО РОКМАТ с 

имеет половинную ширину (соот- диапазоне. Это объясняется тем, ключом /8 (перенос системных 

ветственно, использует 8-разряд- что разные типы ІВМ- файлов). На системном разделе 
ную шину данных). В общем слу- совместимых компьютеров могут кассеты, помимо файлов системы, 

чае на плате находятся два десят- использовать некоторые из этих должны присутствовать файлы 

ка микросхем, 50-контактный областей памяти. Например, в КСО.ЗѴЗ, СОЫРІС.8Ѵ8 и 

разъем интерфейса 8С8І, микро- компьютерах с процессором І8088, АІІТОЕХЕС.ВАТ. При этом файл 

переключатели и поле для уста- область памяти, начинающаяся с ССЖРІС.8Ѵ8 должен содержать 

новки перемычек. Тип С8000К, обычно занята под ПЗУ минимум две строки 

адаптера — РС2В/50 или ВІ05 жесткого диска. В некоторых 

РС2/50 — определяется наличием РС/АТ под этот ВІ05 занята ОЕѴІСЕ = КСО.ЗѴЗ 

на плате микросхем ОЗУ (КАМ), память начиная с адреса ЕООООН. В11РРЕК8 = 8 (конечно, мож- 

ПЗУ (КОМ) и микросхемы Подсоединение двух КСО к но и больше) 
управляющей логики, по- Нозі-адаптеру производится по В файле АІІТОЕХЕС.ВАТ реко- 

зволяющие выполнять загрузку с принципу “дэйзи-цепочки“ (баізу- мендуется установить команду 

системного картриджа КСО. Но об сЬаіпіпв) — Мазіег (управляю- ѴЕКІРѴ ОЫ для проверки опера- 

этом чуть позже. щий) и Зіаѵе (управляемый), то ций ввода/вывода. 
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М5 003 утилиты 

КСО утилиты 

ВАШР 

КСО ВАСКІІР 

0І5КС0РУ 

КСО СОРУ 

Р0І5К 

КСО РАКТІТШ 

РОК МАТ 

КСО РОКМАТ 

КЕЗТОКЕ 

КСО КЕЗТОКЕ 


Рис. 2. 


При использовании КСБ не- 
сомненный интерес представ- 
ляет процедура резервного ко- 
пирования диска (Васкир), осу- 
ществляемая собственной 

утилитой КСО ВАСКІІР. Эта 
утилита дает возможность 
использовать две разновид- 
ности этой операции: ШаЫе 
Васкир и АгсЬіѵаІ Васкир. 
Метод ШаЫе Васкир эф- 
фективен, когда емкость вин- 
честера меньше, чем емкость 
картриджа КСЭ, поскольку 
происходит непосредственное 
копирование файлов. В случае ис- 
пользования АгсЬіѵаІ Васкир, 
перед последующим использова- 
нием файлов они должны быть 
восстановлены утилитой КСО 
КЕЗТОКЕ. Этот метод ре- 
комендуется в случае, когда ем- 
кость используемого винчестера 
больше емкости одного картриджа 
КСО. Решение о том, какой из 
методов применить в конкретном 
случае, зависит и от количества 
дублируемых файлов. Если их 
суммарный размер не превосходит 
44 Мбайт (для ВегпоиШ Вох 44), 
то копирование файлов быстрее 
выполняется при использовании 
ЕІзаЫе Васкир, в противном 
случае эффективнее окажется 
АгсЬіѵаІ Васкир. 


Следует также отметить, что 
фирма Іоте^а обеспечивает совме- 
стимость своих изделий с сетевым 
программным обеспечением фир- 
мы Ыоѵеіі. Тип используемого 
компьютера практически не на- 
кладывает ограничения на приме- 
нение устройств типа ВегпоиШ 
Вох (при использовании соответ- 
ствующего адаптера). Это могут 
быть РС/ХТ, РС/ХТ286, РС/АТ, 
РС/АТ386, Р5/2 (модели 60, 80), 
Сотрад РогіаЫе 286, Сотра^ 
ЭезкРго, Тапбу 3000, ІІпізуз и т.д. 
Например, журнал Мікгосошриіег 
2еіізсЬгіМ упоминает о 70 проте- 
стированных моделях компьюте- 
ров. 

Особенности устройств типа 
ВегпоиШ Вох, такие как емкость. 


скорость передачи данных (на 
уровне параметров жестких 
дисков), возможность смены 
кассеты носителя, высокая 
надежность хранения данных и 
практическая нечувствитель- 
ность к механическим воздей- 
ствиям, обуславливают и 
сферы их применения. Так, 
например, применение КСО в 
наших, зачастую коллективно- 
персональных “писишках“, да- 
ет неплохой шанс сделать их 
действительно персональными. 
Конфиденциальность и сохран- 
ность ценных данных будут га- 
рантированы. Если использовать 
КСО как устройство для загрузки 
ООЗ, то вероятность появления 
вирусов в Вашей системе сводится 
практически к нулю. Применение 
КСО как дополнения к винчестеру 
для хранения, например, больших 
графических массивов, требующих 
оперативного доступа, практи- 
чески не имеет альтернатив (если 
исключить сменные жесткие дис- 
ки). Фирма Іотега гарантирует 
долговечность хранения данных на 
кассетах в течение 5 лет. 


С.Трофимов 
А. Борзенко 


Электронная почта сети ЯЕЬСОМ 

Электронная почта сети Кеісогп создана Демос/* и ИВЦ ИАЭ им. 
Курчатова, и зарегистрирована Международным центром в Стенфор- 
де (США). Сегодня еще можно включиться в национальную и в 
мировую систему электронной почты, став пользователем сети 
КЕІХЮМ. Демос/* обеспечит подключение к сети, а так же, при 
необходимости, поставит оборудование: компьютер, телефонный мо- 
дем и программное обеспечение 

Модемы МNР-5, 2400/4800 Ьрз встроенные и внешние, адаптирован- 
ные к отечественным линиям, эффективно работающие в почтовой 
сети. Коррекция ошибок, компрессия данных, Науез совместимый, 
аттестован Минсвязи СССР. Гарантийное обслуживание 1 год. 




ДЕМОС/*: 113035 Москва, Овчинниковская наб. дом 6/Т, 
телефон: 231-21-29, 231-63-95; Рах: (095) 233.5016; Е-таіІ: іпГо@1щ.сІетоз.8и 

По вопросам заключения договоров на подключение к сети Кеісот обращаться по телефонам Демоса/* и телефону ИВЦ: 1 96-72-50. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 



1Ѵ1ы продолжаем публикацию статьи о безопасности 
компьютерных систем, начатую в прошлом номере. Когда 
журнал с первой частью статьи был уже в типографии, мы 
узнали о некоторых интересных событиях, имевших место в 
нашей стране летом этого года. Более подробно об этом вы 
можете прочитать в еженедельнике “Коммерсантъ" №40 (90) 
от 30 сентября-6 октября 1991 года, мы же лишь вкратце 
напомним вам суть дела. Случилось именно то, о чем 
КомпьютерПресс предупреждал уже давно, и наиболее 
настойчиво — в предыдущем номере. Во Внешэкономбанке СССР 
начальником отдела вычислительного центра было совершено 
крупное хищение валюты. Кража проводилась с помощью 
компьютерной программы, автором которой был сам 
преступник. Эта программа использовалась в банке уже 10 лет. 
Самое потрясающее во всей этой истории то, что никто 
происшедшему особенно не удивился, а главное — не 
обеспокоился. Соответствующий отклик это событие вызвало 
только в узких компьютерных кругах, занимающихся 
компьютерной безопасностью. Ни банковские работники, ни 
многочисленные брокерские конторы на событие почМи не 
отреагировали. Они по-прежнему не понимают или не хотят 
понимать, что ходят по лезвию ножа. Вот уж, поистине, 
олимпийское спокойствие. Видно, нашего мужика ничем не 
прошибешь — он не крестится и после того, как грянул гром. 

И, между прочим, совершенно напрасно. Нет никаких сомнений, 
что компьютерная преступность, как и всякая другая 
преступность в нашей стране, будет расти. И мы к этому 
совершенно не готовы. У нас любой мало-мальски 
квалифицированный пользователь может залезть в 
компьютерную сеть, устроить там погром, получить 
конфиденциальную информацию и спокойно с достоинством 
удалиться. У нас ведь нет специалистов по компьютерной 
преступности! У нас нет соответствующих законов! 
Следователь по делу кражи в ВЭБ признался, что ничего не 
смыслит в компьютерах. Интересно, много ли они там 
нарасследуют? Ведь компьютерная программа могла 
переводить деньги не только на те счета, которые 
“ засветились “. Кто в этом сможет разобраться? Да, видно, 
чудеса в нашей стране еще только начинаются. Мы, как те 
глупцы, предпочитаем учиться на своих собственных ошибках, 
не признавая чужого опыта. Ну что ж, будем надеяться, что 
естественный отбор все же поможет продвинуться в бизнесе 
людям умным, а не только хитрым и пронырливым. Как 
говорится, что бог ни делает — все к лучшему. 
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Безопасность 
компьютерных систем 


“По-настоящему безопасной можно 
считать лишь систему , которая 
выключена, замурована в бетонный 
корпус, заперта в помещении со 
свинцовыми стенами и охраняется 
вооруженным караулом, — но и в 
этом случае сомнения не оставляют 
меня". 

Юджин X. Спаффорд 

2. Безопасность программ 

Условимся, что под термином “программа 11 мы в 
равной степени будем понимать обычные программы 
пользователей; специальные программы, рассчитанные 
на нарушение безопасности системы; а также разно- 
образные системные утилиты и коммерческие при- 
кладные программы, которые отличаются более высо- 
ким профессиональным уровнем разработки и, тем не 
менее, могут содержать отдельные недоработки, по- 
зволяющие захватчикам атаковать системы. 

Программы могут порождать проблемы двух типов: 
они, во-первых, могут перехватывать и модифициро- 
вать данные в результате действий пользователя, ко- 
торый к этим данным не имеет доступа; и, во-вторых, 
используя упущения в защите компьютерных систем, 
программы могут или обеспечивать доступ к системе 
пользователям, не имеющим на это права, или блоки- 
ровать доступ к системе законных пользователей. 

К сожалению, количество возможных слабых точек, 
которые могут содержаться в той или иной программе, 
значительно превышает число известных технологий 
устранения экспозиций. Это обусловлено двумя при- 
чинами: 

- во-первых, качество программы всегда не превышает 
квалификации ее разработчика: очевидные экспози- 
ции и нарушения могут быть выявлены и устранены 
достаточно легко, однако, чем выше уровень подго- 
товки программиста, тем более неявными (даже для 
него) становятся допускаемые им ошибки и тем бо- 
лее тщательно и надежно он способен скрыть умыш- 


ленные механизмы, разработанные для нарушения 
безопасности системы; 

- во-вторых, имеет место трудно разрешимый компро- 
мисс между эффективностью и удобством компью- 
терной системы в работе и степенью обеспечения в 
ней требований безопасности. Чем более высокие 
требования предъявляются к безопасности системы, 
тем большее количество ресурсов системы затрачива- 
ется на обеспечение этих требований, тем сильнее 
снижается производительность системы и увеличи- 
ваются сроки решения задач, наконец, тем неудобнее 
работать в данной системе пользователям. С другой 
стороны, чем больше ресурсов выделяется для реше- 
ния текущих задач, тем меньше возможностей по 
обеспечению должного уровня безопасности. 

В основном небезопасность программ состоит в том, 
что они могут быть использованы как средства полу- 
чения критичной информации (данных), циркулиру- 
ющей в системе, тем более, что данные в компьютер- 
ной системе обычно хранятся в виде, непонятном для 
большинства людей. 

Впрочем, целью атаки могут быть и сами про- 
граммы. Причин тому несколько: 

1. В современном мире программы могут быть това- 
ром, приносящим немалую прибыль, особенно тому, 
кто первый начнет тиражировать программу в ком- 
мерческих целях и оформит авторские права на нее. 
Поэтому опасность похищения почти готовой про- 
граммы конкурентом — не такая уж надуманная 
возможность. 

2. Программы могут становиться также объектом 
атаки, имеющей целью модифицировать эти про- 
граммы некоторым образом, что позволило бы в бу- 
дущем провести атаку на другие объекты системы. 
Особенно часто объектом атак такого рода стано- 
вятся программы, реализующие функции защиты си- 
стемы. 

Рассмотрим несколько типов программ и приемы, 
которые наиболее часто используются для атак про- 
грамм и данных. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 


2.1 Как залезть в программу 

Как залезть в программу? Очень просто — через 
люк! 

Люком называется не описанная в документации на 
программный продукт возможность работы с этим про- 
граммным продуктом. Сущность использования люков 
состоит в том, что при выполнении пользователем не- 
которых не описанных в документации действий он 
получает доступ к возможностям и данным, которые в 
обычных условиях для него закрыты (в частности — 
выход в привилегированный режим). 

Люки чаще всего являются результатом забывчиво- 
сти разработчиков. В процессе разработки программы 
разработчики часто создают временные механизмы, 
облегчающие ведение отладки за счет прямого доступа 
к отлаживаемым частям продукта. Пусть, например, 
для начала работы с продуктом требуется выполнить 
некоторую последовательность действий, предусмот- 
ренных алгоритмом, — ввести пароль, установить зна- 
чения некоторых переменных и т.п. При нормальной 
работе продукта эти действия имеют определенный 
смысл. Но во время отладки, когда разработчику необ- 
ходимо тестировать некоторые внутренние части про- 
граммы и волей-неволей приходится выполнять ту же 
операцию входа добрый десяток — а то и более — раз 
на дню, безобидные в общем-то правила, затрудня- 
ющие тем не менее доступ к отлаживаемым частям, 
начинают не на шутку раздражать. Что же делает 
программист? Правильно: в течение получаса он про- 
граммирует некоторый дополнительный механизм, не 
предусмотренный изначальным алгоритмом про- 
граммы, но позволяющий не выполнять надоедливых 
действий или выполнять их автоматически — напри- 
мер, при нажатии определенной клавиши 
(комбинации клавиш) или при вводе определенной 
последовательности символов. Все — люк готов! 

По окончании отладки большинство люков убира- 
ется из программы; но люди есть люди — зачастую 
они забывают о существовании каких-то мелких 
“лючков**. Иногда, правда, разработчики сознательно 
оставляют люки в своих продуктах, особенно в ранних 
версиях, когда весьма вероятна возможность доработки 
продукта. 

Одним из наиболее показательных примеров 
использования “забытых** люков является, пожалуй, 
широко известный в компьютерном мире инцидент с 
вирусом Морриса. Одной из причин, обусловивших 
возможность распространения этого вируса, была 
ошибка разработчика программы электронной почты, 
входящей в состав одной из версий операционной си- 
стемы ІШІХ, приведшая к появлению малозаметного 
лючка. Для вас, наверное, будет небесполезно знать, 
что американские специалисты оценивают ущерб, на- 
несенный в результате этого инцидента, более чем в 
100 миллионов долларов. 

Люки могут образовываться также в результате ча- 
сто практикуемой технологии разработки программ- 
ных продуктов “сверху вниз**. При этом программист 


приступает к написанию сразу управляющей 
программы, заменяя предполагаемые в будущем 
подпрограммы так называемыми “заглушками** — 
группами команд, имитирующими или просто 
обозначающими место подсоединения будущих 
подпрограмм. В процессе разработки по мере 
готовности реальных подпрограмм эти подпрограммы 
заменяют соответствующие заглушки. В теории 
моментом завершения разработки конечной 
программы по такой технологии можно считать 
момент замены последней заглушки реальной 
подпрограммой (при условии, что все подпрограммы 
отлажены и синхронизированы). 

В действительности дело обстоит несколько слож- 
нее. Вся беда в том, что авторы часто оставляют за- 
глушки в конечном программном продукте, передава- 
емом в эксплуатацию. Делают это порой неумыш- 
ленно: например, на ранних стадиях разработки пред- 
полагалось наличие в конечном продукте некоторой 
подпрограммы, однако в процессе разработки выясни- 
лось, что эта подпрограмма в силу каких-либо причин 
не нужна. Но заглушка-то на предполагавшемся месте 
подключения подпрограммы осталась! Более того, уда- 
лить заглушку, не заменяя ее подпрограммой, бывает 
весьма сложно. Все это может спровоцировать про- 
граммиста на то, чтобы оставить такую заглушку на 
месте “до лучших времен**. 

Возможен вариант, когда заглушки оставляются в 
конечной программе сознательно, в расчете на под- 
ключение в дальнейшем к работающей программе но- 
вых подпрограмм, реализующих некоторые новые воз- 
можности, либо предполагая возможное подключение 
к программе тестирующих средств для более точной 
настройки программы. Будет ли пользователь данной 
программы приобретать эти “новые возможности**, 
обратится ли он когда-нибудь к разработчику про- 
граммы с просьбой более тонко настроить его де- 
тище — это еще под вопросом, а ведь заглушки-то 
стоят! Кто может дать гарантию, что в один прекрас- 
ный момент такой заглушкой кто-нибудь не восполь- 
зуется для подключения к программе совсем иной 
подпрограммы, работающей в интересах этого “кого- 
нибудь", а не законного пользователя? 

Наконец, еще одним распространенным источником 
люков является так называемый “неопределенный 
ввод**. 

Допустим, некто предлагает вам программу, кото- 
рой можно управлять с помощью определенных ко- 
манд или даже просто путем ввода в ответ на запросы 
программы символов “Ѵ“ (“Да") или “Ы“ (“Нет"). А 
что произойдет, если вы в ответ на запрос введете, 
предположим, “А“ или вместо верной команды введете 
какую-либо абракадабру? Если программа написана 
хорошо, то такие случаи должны вызывать появление 
на экране сообщения типа “НЕВЕРНЫЙ ВВОД** и 
повтор запроса. 

Однако не так уж редка ситуация, когда программа 
создается неопытным программистом, исходящим из 
предположения, что пользователи будут работать с его 
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программой всегда корректно. В этом случае реакция 
программы на неопределенный ввод может быть в 
лучшем случае непредсказуемой (когда при повторном 
вводе той же неверной команды программа реагирует 
каждый раз по-разному); гораздо хуже, если про- 
грамма в результате одинакового “неопределенного" 
ввода выполняет некоторые повторяющиеся дей- 
ствия — это дает потенциальному захватчику возмож- 
ность планировать свои действия по нарушению безо- 
пасности, 

В любом случае существует потенциальная возмож- 
ность нарушения безопасности системы. 

Неопределенный ввод — частная реализация ПРЕ- 
РЫВАНИЯ. То есть в общем случае захватчик может 
умышленно пойти на создание в системе некоторой 
нестандартной ситуации, позволившей бы ему выпол- 
нить необходимые действия. Например, он может 
искусственно вызвать аварийное завершение про- 
граммы, работающей в привилегированном режиме, с 
тем, чтобы перехватить управление, оставшись в этом 
привилегированном режиме. Классический пример та- 
кого рода люков — ассемблерные команды ЗРІЕ и 
5РАЕ в ЕС ЭВМ, допускающие в определенных ситу- 
ациях перехват пользователем (или его программой) 
управления в режиме супервизора. 

Борьба с возможностью прерывания (в терминоло- 
гии безопасности) в конечном итоге выливается в 
предусмотрение при разработке программ комплекса 
механизмов, образующих так называемую “защиту от 
дурака". Смысл этой защиты состоит в том, чтобы га- 
рантированно отсекать всякую вероятность обработки 
неопределенного ввода и разного рода нестандартных 
ситуаций (в частности, ошибок). Короче, качественная 
программа должна работать корректно и не приводить 
к появлению возможности нарушения безопасности 
компьютерной системы, даже если с самой програм- 
мой работают некорректно — например, если за кла- 
виатурой терминала случайно оказалась обезьяна. 

Таким образом, люк (или люки) может присутство- 
вать в программе ввиду того, что программист: 

1 ) забыл удалить его; 

2) умышленно оставил его в программе для обеспече- 
ния тестирования или выполнения оставшейся части 
отладки; 

3) умышленно оставил его в программе в интересах 
облегчения окончательной сборки конечного про- 
граммного продукта; 

4) умышленно оставил его в программе с тем, чтобы 
иметь скрытое средство доступа к программе уже по- 
сле того, как она вошла в состав конечного продукта. 

В первом случае люк — неумышленная, но серьез- 
ная брешь в безопасности системы. Во втором и 
третьем случаях люк — серьезная экспозиция безо- 
пасности системы. Наконец, в последнем случае 
люк — первый шаг к атаке системы. 

В любом случае люки — это возможность получить 
управление вашей системой в обход защиты. 


2.2 “Бойтесь данайцев, дары приносящих!" 

Существуют программы, реализующие, помимо 
функций, описанных в документации, и некоторые 
другие функции, в документации не описанные. Такие 
программы называются троянскими конями. 

Например, вы запускаете какую-то нужную вам 
программу — графический пакет, расчетную задачу 
или игру, наконец, — а через некоторое время обна- 
руживаете, что в вашей директории исчезли все 
файлы. Поскольку кроме запуска известной вам про- 
граммы вы ничего другого не делали, вполне вероятно, 
что вы заподозрите что-то неладное и решите запу- 
стить ту же программу в другой (лучше специально 
для этого созданной) директории. Если эффект повто- 
рится — вы имеете дело с “троянским конем" в ком- 
пьютерном исполнении. 

Далеко не всегда обнаружить троянского коня бы- 
вает так просто — вероятность обнаружения тем 
больше, чем очевиднее результаты действия троян- 
ского коня. А если задачей троянского коня является 
не удаление ваших файлов, а изменение их защиты? 
Явно вы этого не увидите, но каково будет ваше удив- 
ление, когда через некоторое время выяснится, что 
конфиденциальные данные, содержавшиеся в одном из 
ваших файлов (например, проект важного документа), 
стали известны всем. Проверяете наличие файла — на 
месте, проверяете защиту файла — а оказывается, его 
может читать любой! 

Однако такие фиксированные результаты представ- 
ляют очень опасную для троянского коня угрозу 
разоблачения его деятельности и, соответственно, 
обнаружения. Более сложный троянский конь может 
быть запрограммирован таким образом, чтобы по 
изменении защиты файлов (в нашем примере) пода- 
вать захватчику (лицу, заинтересованному в срабаты- 
вании троянского коня) некоторый условный сигнал о 
доступности файлов; после выдачи сигнала троянский 
конь некоторое время выжидает, а затем возвращает 
защиту файлов в исходное состояние. 

Такой алгоритм позволяет захватчику в течение не- 
которого времени делать с вашими файлами все, что 
угодно, и никаких следов атаки после этого не оста- 
ется. Вы же остаетесь в полном счастливом неведении, 
т.е. с носом. 

2.3 Какая неожиданность! 

“Логической бомбой“ обычно называют программу 
или даже участок кода в программе, реализующий не- 
которую функцию при выполнении определенного 
условия. 

Я понимаю, что такое определение достаточно рас- 
плывчато, поэтому попытаюсь его пояснить. 

Прежде всего “логическая бомба" отличается от 
других программ тем, что, “взрываясь", она реализует 
функцию, неожиданную или, хуже того, нежеланную 
для пользователя. Например, удаляет некоторые дан- 
ные или разрушает некоторые системные структуры 


2 Зак. 2503 
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данных. Впрочем, функция логической бомбы может 
быть и более безобидной: например вывод на экран 
терминала или на принтер некоторого сообщения 
шутливого или оскорбительного характера. 

Бомбы, существующие в виде отдельных программ, 
обычно имеют малопонятные или, наоборот, любопыт- 
ные имена. Ничего не подозревающий пользователь, 
получивший подобный “сюрприз", каким-либо обра- 
зом, естественно, пробует запустить программу, чтобы 
понять, что она делает — вот тут-то и начинается са- 
мое интересное! Классическим примером бомбы явля- 
ется программа, распространенная в американских 
компьютерных сетях под названием Коскѵібео. После 
ее запуска на экране дисплея можно увидеть мультип- 
ликационные картинки с американской рок-певицей 
Мадонной, причем показ завершается выдачей сооб- 
щения следующего содержания: “Только идиот 

использует свой компьютер для того, чтобы рассмат- 
ривать видеозвезд!". Во время демонстрации бомба 
удаляет себя, но заодно удаляет и все файлы на до- 
ступных для нее дисках. 

Есть также основания предполагать, что не слиш- 
ком широко известный инцидент с остановкой глав- 
ного конвейера на Горьковском автозаводе был также 
не чем иным, как “взрывом" “логической бомбы". 

Естественно, поняв, что представляет собой про- 
грамма-“подарок“, пользователь удаляет ее, но это за- 
частую уже не имеет значения: бомба-то взорвалась. А 
уж разрушения в ваши данные она может внести са- 
мые сокрушительные: это определяется только уров- 
нем подготовки и изощренностью автора бомбы. 

Более сложным является случай, когда программа, 
осуществляющая некоторую законную обработку, со- 
держит в себе участок кода, который срабатывает при 
выполнении в системе некоторых условий, например 
при наступлении определенной даты или при обнару- 
жении файла с определенным именем. Такие 
вкрапления в тело обычных программ также можно 
считать “логической бомбой". 

Мировая компьютерная общественность достаточно 
хорошо знакома с логическими бомбами. Логическая 
бомба является одним из излюбленных способов мести 
программистов компаниям, которые их уволили или 
чем-либо обидели. При этом чаще всего срабатывание 
бомбы ставится в зависимость от установки в системе 
даты — так называемые “часовые 1 * бомбы. Это очень 
удобно: допустим, программист знает, что его уволят 1 
марта; в таком случае он может установить “часовую" 
бомбу на взрыв, допустим, б июля или даже на Рож- 
дество, когда сам он будет уже вне пределов досяга- 
емости для пострадавшей компании*. 

Ориентируя бомбу на установку определенной даты, 
можно также закладывать бомбы впрок: например, 


* В этом отношении интересна высказанная одним из 

администраторов систем мысль, что при увольнении 
системного программиста будет лучше, если глава фирмы 
проводит его до дверей офиса, вежливо попрощается и подаст 
пальто. 


можно определить, что бомба должна сработать 30 
февраля. Поскольку такой даты не существует, бомба 
не взорвется до тех пор, пока знающий о ней 
злоумышленник преднамеренно (или ни о чем не 
догадывающийся оператор системы — по ошибке) не 
установит системные часы в соответствующее поло- 
жение. 

2.4 Колбаса и компьютер 

Речь пойдет о биче банковских компьютерных си- 
стем — атаке “салями". 

Чтобы понять смысл такой атаки, полезно вспо- 
мнить технологию изготовления известного сорта кол- 
басы, которая создается путем соединения в общее це- 
лое множества мелких кусочков мяса. Получается до- 
статочно вкусно. 

Теперь рассмотрим смысл компьютерной атаки. В 
банковских системах ежедневно производятся тысячи 
операций, связанных с безналичными .расчетами, пе- 
реводами сумм, отчислениями и т.д. Во многих из та- 
ких операций возникает проблема вычисления различ- 
ного рода долей от некоторой величины. Вычислить 
необходимый процент можно с разной степенью точ- 
ности, и поэтому еще при разработке систем устана- 
вливается правило округления (или усечения), исполь- 
зуемое при выполнении всех операций. 

Классическим примером атаки салями является, 
возможно, вымышленная история о вычислении доли в 
6,5% от 102,87 долл, для 31 дня. Несложные вычис- 
ления дают: 

31 / 365 * .065 * 102.87 = 0.5495726 долл. 

С точки зрения банка, различающего в качестве са- 
мой маленькой величины только целый цент, эта ве- 
личина не имеет смысла, также как вряд ли кто-ни- 
будь из нас сможет доступно объяснить, что такое 
“полкопейки**. Поэтому в банках принято правило, по 
которому величины, превышающие половину цента, 
округляются с избытком (или просто округляются) до 
целого цента, а величины менее половины цента про- 
сто отбрасываются. 

Вся хитрость состоит в том, как запрограммировать 
обработку отбрасываемых долей и округлений. Можно, 
конечно, просто удалять несущественные величины. 
Но можно и не удалять эти величины, а накапливать 
их постепенно на некоем специальном счете. Там пол- 
цента, тут полцента... — а в сумме? Как свидетель- 
ствует практика, сумма, составленная буквально из 
ничего, за пару лет эксплуатации “хитрой" программы 
в среднем по размеру банке, может исчисляться тыся- 
чами долларов. 

Можно сказать, что атака салями — компьютерная 
реализация известной поговорки “С миру по нитке — 
голому рубаха". 

Компьютерные вычисления по природе склонны к 
мелким погрешностям, особенно при одновременной 
обработке больших и маленьких величин. С другой 
стороны, для различных практических нужд человеку 
требуется различная точность вычислений. Расплачи- 
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ваясь, например, в такси, вы можете позволить себе 
поправку счета на размер “чаевых**, но рассчитывая 
орбиту искусственного спутника, вы будете заинтере- 
сованы в вычислении всех величин с точностью “до 
энного знака после запятой**. Однако обработка дроб- 
ных величин на ЭВМ связана с достаточно сложными 
вычислениями. Именно ввиду этой изначальной слож- 
ности работы с дробными величинами обнаружить в 
программе код, реализующий атаку салями, бывает 
весьма непросто. А это в свою очередь объясняет регу- 
лярное появление сообщений о все новых и новых 
атаках этого типа. 

2.5 Скрытые каналы 

Теперь поговорим о программах, передающих 
информацию лицам, которые в обычных условиях эту 
информацию получать не должны. Называются такие 
необычные способы извлечения информации скры- 
тыми каналами. 

В тех системах, где ведется обработка критичной 
информации, программист не должен иметь доступа к 
обрабатываемым программой данным после начала 
эксплуатации этой программы. Например, банковский 
программист не должен иметь доступа к именам или 
счетам вкладчиков и клиентов, как не должен знать 
порядка обслуживания клиентов. В процессе отладки 
программы разработчику допускается предоставление 
ограниченного объема реальных данных для проверки 
работоспособности программы, но предоставление ре- 
альных данных после сдачи программы в эксплуата- 
цию не имеет оправдания. 

Из факта обладания некоторой служебной инфор- 
мацией можно извлечь достаточно немалую выгоду, 
хотя бы элементарно продав эту информацию 
(например, список клиентов) конкурирующей фирме. 
Поэтому нетрудно предположить, что кто-либо из со- 
трудников будет заинтересован в том, чтобы иметь 
возможность такую информацию получать. 

Достаточно квалифицированный программист 
всегда может найти способ скрытой передачи инфор- 
мации; при этом программа, предназначенная для со- 
здания самых безобидных отчетов может быть немного 
сложнее, чем того требует задача. Для скрытой пере- 
дачи информации можно с успехом использовать раз- 
личные элементы формата “безобидных** отчетов, на- 
пример, разную длину строк, пропуски между стро- 
ками, наличие или отсутствие служебных заголовков, 
управляемый вывод незначащих цифр в выводимых 
величинах, количество пробелов или других символов 
в определенных местах отчета и т.д. 

Например, определенную информацию может нести 
появление в отчете вместо служебного заголовка 
“ТОТАЬ“ другого заголовка — “ТОТАІД**. Разница 
всего в один символ, но именно его наличие или 
отсутствие и может быть сигналом осведомленному о 
канале захватчику (например, о том, что в системе 
появился файл с определенным именем). В данном 
случае имеет место 1-битовый скрытый канал, так как 


за один раз передается один бит информации 
(наличие или отсутствие символа “8“). 

Однако возможна ситуация, когда захватчик не бу- 
дет иметь доступа ко всем отчетам, создаваемым 
“хитрой** программой, и таким образом он будет ли- 
шен возможности пользоваться своим скрытым кана- 
лом непосредственно. • 

В таком случае программист может обеспечить, на- 
пример, вызов в определенных ситуациях более безо- 
пасной программой, непосредственно обрабатывающей 
интересующие захватчика данные, менее безопасной 
программы, которой и будут переданы критичные дан- 
ные. А уж вызванная программа может создавать за- 
маскированный, внешне “безобидный** отчет, доступ- 
ный для просмотра захватчику. 

Еще более сложным может быть случай, когда за- 
хватчик не имеет возможности просматривать замас- 
кированные отчеты или обеспечивать вызов подпрог- 
рамм-шпионов, но имеет возможность доступа к ком- 
пьютеру во время работы интересующей его про- 
граммы. В такой ситуации возможно создание специ- 
ального массива данных непосредственно в оператив- 
ной памяти компьютера, куда программа, содержащая 
скрытый канал, будет пересылать критичную инфор- 
мацию. Причем, опять же, информация может быть 
представлена в виде служебных символов, старт-стоп- 
ных сигналов для магнитных лент, символов управле- 
ния консолью и т.д. 

Как видно из приведенных примеров, для получе- 
ния относительно небольших объемов информации за- 
хватчик вынужден проделать достаточно большую ра- 
боту. Поэтому скрытые каналы наиболее применимы в 
ситуациях, когда захватчика интересует даже не со- 
держание информации, а, допустим, факт ее наличия 
(например, наличие в банке расчетного счета с опре- 
деленным номером). Можно предположить и более 
изощренную ситуацию: с помощью скрытого канала 
захватчик получит сигнал о появлении в системе 
файла с определенным именем, что в свою очередь 
служит признаком работы в системе некоторого про- 
цесса, позволяющего провести атаку иного типа. 

2.6 Жадность — порок! 

Большинство методов нарушения безопасности на- 
правлены на то, чтобы получить доступ к данным, не- 
допускаемый системой в нормальных условиях. 
Однако не менее интересным для захватчиков явля- 
ется доступ к управлению самой компьютерной систе- 
мой или изменение ее качественных характеристик. 
Это может потребоваться для того, чтобы явно исполь- 
зовать компьютерную систему в своих целях (хотя бы 
для бесплатного решения своих задач) либо просто 
заблокировать систему, сделав ее недоступной другим 
пользователям. Такой вид нарушения безопасности си- 
стемы называется “отказом в обслуживании** или 
“отказом от пользы**. 

Некоторые компьютеры, особенно в исследователь- 
ских центрах, имеют так называемые “фоновые** за- 
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дачи, постоянно решаемые, но с очень маленьким 
приоритетом. Обычно это задачи, требующие для ре- 
шения очень большого машинного времени, но не осо- 
бенно срочные (типа вычисления числа е или Пи с 
очень большой степенью точности). Низкий приоритет 
делает возможным решение этих задач только при 
условии, что в системе нет задач с более высоким 
приоритетом. Однако по недосмотру либо в результате 
ошибки, либо умышленно приоритет такой “фоновой 1 * 
задачи может быть существенно повышен: в этом 
случае бывшая “тихоходная** задача захватывает 
процессор в монопольное использование, блокируя 
выполнение всех других вычислений. 

Такого рода программы, захватывающие некоторый 
ресурс в монопольное использование, называются 
жадными программами. Ведь чтобы остановить выпол- 
нение какого-либо задания, вовсе не обязательно 
захватывать именно процессор. 

Например, если известно, что на некотором этапе 
задача, которую нужно заблокировать, должна выпол- 
нять вывод на печать некоторого отчета, можно забло- 
кировать доступ к принтеру. В таком случае оператор 
системы будет видеть, что обработка заданий проходит 
“нормально** — процессор-то не заблокирован и дру- 
гие задачи нормально решаются — и так до тех пор, 
пока не прибежит разгневанный хозяйн заблокирован- 
ной задачи в сопровождении администратора системы. 

Изобрести подходящую “долгоиграющую** задачу 
для того, чтобы намертво заблокировать систему, не- 
сложно — достаточно запрограммировать в обычной 
программе явный или неявный бесконечный цикл. 

В явном виде бесконечный цикл можно определить, 
поставив условием окончания цикла условие, которое 
никогда не будет выполнено. Ну, например, запро- 
граммировать выполнение цикла, пока 1 больше 0. 
Да, единица всегда будет больше нуля! Таким 
образом, цикл будет выполняться хоть до второго 
пришествия. 

В неявном виде цикл можно организовать с по- 
мощью двух команд перехода, которые передают 
управление друг другу. Это что-то вроде лемовских 
“сепулек** и “сепулькарий**. 

Бороться с бесконечными циклами можно с помо- 
щью имеющейся в большинстве систем возможности 
устанавливать предельное количество машинного вре- 
мени для решения данной задачи. В таком случае по 
исчерпании задачей выделенного лимита времени, си- 
стема автоматически останавливает задачу. Однако, 
во-первых, установленный лимит можно обойти или 
постоянно изменять, а во-вторых, сославшись на дли- 
тельность решения задачи, можно потребовать от ад- 
министратора системы вообще снять какие-либо вре- 
менные ограничения для вашей задачи. 

Кроме того, существует еще одна тонкость в исчис- 
лении машинного времени. Дело в том, что машинное 
время измеряется в единицах времени, затраченного 
центральным процессором на выполнение данной за- 
дачи. Таким образом, время ожидания задачей некото- 
рого события — например окончания операции вво- 


да/вывода — не учитывается. В некоторых системах, 
если задача запрашивает выполнение операции вво- 
да/вывода, то на время ожидания этой задачей завер- 
шения запрошенной операции система “выключает** 
счетчик времени процессора для данной задачи. Но 
можно ведь создать программу ввода/вывода с беско- 
нечным циклом! В таком случае остановится и внеш- 
няя программа, вызвавшая подпрограмму-ловушку. 

Можно упомянуть также о знакомой программистам 
возможности вхождения двух процессов в клинч. 

Допустим, в системе решаются две задачи — А и Б. 
Предположим также, что они имеют следующие алго- 
ритмические участки: 

задача А задача Б 


захватить ресурс 1 
захватить ресурс 2 
освободить ресурс 1 


захватить ресурс 2 
захватить ресурс 1 
освободить ресурс 2 


Теперь попытаемся представить, что произойдет, 
если обе задачи выйдут на выполнение этих участков 
одновременно. При этом задача А захватит в исполь- 
зование ресурс 1 (допустим, принтер); задача Б в то 
же время захватит ресурс 2 (предположим, плоттер). 
Далее задача А попробует захватить ресурс 2, но он-то 
уже захвачен задачей Б! Аналогично и с задачей Б, 
которой требуется захватить ресурс 1, уже захвачен- 
ный задачей А. 

Казалось бы, чего проще — пускай одна из задач 
освободит ресурс — и конфликт разрешится. Но в 
том-то весь секрет, что освобождение ресурса в обеих 
задачах зависит от выполнения захвата второго (в 
каждой задаче своего) ресурса, т.е. не выполнив за- 
хвата, задача не освободит другого ресурса. 

Такое безвыходное положение, весьма похожее на 
ситуацию с двумя баранами на одном мосту из извест- 
ной детской сказки, и называется клинчем. 

Клинч может возникать случайно, в силу неудачно 
сложившихся обстоятельств; может возникнуть в ре- 
зультате низкого качества программирования; но нет, 
однако, принципиальной невозможности провокации 
неким злоумышленником ситуации, чреватой вхожде- 
нием в клинч. 

В большинстве современных систем существуют 
специальные средства разрешения такого рода кон- 
фликтов. Более того, в настоящее время уже при про- 
ектировании систем предусматривается наличие встро- 
енных механизмов, нацеленных на выявление и 
предотвращение угрожающих ситуаций. И тем не ме- 
нее угроза клинча остается. 

Насколько опасной может быть блокировка ком- 
пьютерной системы? 

Прежде всего, спросите военных, насколько опасной 
может быть блокировка компьютера, управляющего 
различного рода системами раннего обнаружения или 
той же противовоздушной обороньі. 

Можно поинтересоваться у врачей, насколько серь- 
езными могут быть последствия блокировки компьюте- 
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ров, осуществляющих мониторинг больных в реанима- 
ционном отделении. 

Уже из этих примеров становится очевидным, что 
“отказ от обслуживания" чрезвычайно опасен для так 
называемых систем реального времени — систем, 
управляющих некоторыми технологическими процес- 
сами, осуществляющих различного рода синхрониза- 
цию и т.д. 

2.7 Компьютерные вирусы 

Компьютерные вирусы — тема для отдельного 
очень интересного и очень длинного разговора. 

Серьезного отношения компьютерные вирусы по- 
требовали к себе относительно недавно; настолько не- 
давно, что американский институт стандартов до сих 
пор не дал четкого определения компьютерного ви- 
руса, благодаря чему в трудах и работах 
специалистов-компьютерщиков царит полйейший 
плюрализм в трактовке этого термина. 

В последнее время распространилось следующее 
определение: 

КОМПЬЮТЕРНЫЙ ВИРУС — набор команд 
(программных или иных), который производит и рас- 
пространяет свои копии в компьютерных системах 
и/или компьютерных сетях и преднамеренно выпол- 
няет некоторые действия, нежелательные для закон- 
ных пользователей систем. 

Рассмотрим подробнее ключевые элементы опреде- 
ления, чтобы лучше понять суть явления. 

Компьютерный вирус — набор команд. Ко- 
манды, составляющие тело вируса, могут иметь самую 
различную природу. Сюда могут входить команды ка- 
кого-либо языка(-ов) программирования (наиболее 
распространенный случай), микропрограммные ин- 
струкции, управляющие символы и комбинации в те- 
лекоммуникационных сообщениях, различного рода 
параметры, а также команды языка управления зада- 
ниями. Таким образом, перспективное каноническое 
определение вируса не должно ограничивать среду 
существования вируса. 

Компьютерный вирус распространяется. Ка- 
ноническое определение вируса не должно также 
ограничивать способы распространения вируса. Важно 
то, что вирус может репродуцировать себя в одной или 
нескольких компьютерных системах**. 

Существенно также то, что вирус в принципе мо- 
жет распространять набор команд, отличающийся по 
форме или содержанию от оригинала. Короче, вирус 
со временем может эволюционировать. 

Компьютерный вирус выполняет нежелатель- 
ные действия. Попадая тем или иным способом в 


** Кстати, именно способность саморазмножаться отличает 
программу-вирус от логической бомбы. 


вашу Систему, вирус самокопирует себя в различные 
места памяти системы, а затем (либо одновременно с 
этим) производит в вашей системе изменения, в луч- 
шем случае не приводящие к катастрофическим для 
вас последствиям (например, высвечивание на экране 
терминала некоторого сообщения), а в худшем — де- 
лающие вашу систему неработоспособной. Заметим, 
что большинство вирусов изначально небезобидны. 

Так как вирус самостоятельно обеспечивает свое 
размножение и распространение, вам, в случае обна- 
ружения вами вируса, необходимо проверить всю вашу 
систему, уничтожая копии вируса. Если вам удалось 
уничтожить все копии вируса, вы можете сказать, что 
вылечили вашу систему; в противном случае уцелев- 
шие копии снова саморазмножатся и все неприятности 
повторятся сначала. 

Своим названием компьютерные вирусы обязаны 
определенному сходству с вирусами естественными: 
способности к саморазмножению; высокой скорости 
распространения; избирательности поражаемых систем 
(каждый вирус поражает только определенные си- 
стемы или однородные группы систем); способности 
“заражать" еще незараженные системы; трудности 
борьбы с вирусами и т.д. В последнее время к этим 
особенностям, характерным для вирусов компьютер- 
ных и естественных, можно добавить еще и постоянно 
увеличивающуюся быстроту появления модификаций 
и новых поколений вирусов. Только если в случае 
вирусов естественных эту скорость можно объяснить 
могуществом и изобретательностью природы, то 
вирусы компьютерные скоростью возникновения новых 
штаммов обязаны исключительно недосмотру или 
бредовым идеям людей определенного склада. 

Приведем пример подпрограммы-вируса. Она со- 
стоит из псевдокоманд ООЗ и подпрограмм — малень- 
ких внутренних программ (составляющие их инструк- 
ции хранятся отдельно от главной программы), вы- 
полняющих некоторые специальные функции всякий 
раз, когда к ним обращаются. 

ІНіз: - ГіпсШІе 

ШАО(ІНіз) 

Іос: = зеагсН(ІНіз) 

іпзеіі(іос) 

ЗТОКЕ(ІНІз) 

Подпрограмма под названием НпбРПе обращается к 
каталогу выполняемых файлов или программ на диске, 
берет произвольное имя файла и присваивает имя 
этого файла переменной ІНіз (этот). 

В следующей строке программы используется псев- 
докоманда ЭОЗ ШАБ (загрузить), с помощью 
которой файл помещается в оперативную память 
компьютера. 

Другая подпрограмма под названием зеагсН (поиск) 
просматривает только что загруженную программу в 
поисках инструкции, которая могла бы послужить 
подходящим местом, куда можно занести вирус. Когда 
процедура зеагсН находит такую инструкцию, она 
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определяет соответствующий номер строки и присва- 
ивает его в качестве значения переменной Іос. 

Теперь все готово для того, чтобы подпрограмма-ви- 
рус могла проникнуть в произвольно выбранную из 
каталога программу. Подпрограмма іпзегі (вставить) 
заменяет выбранную инструкцию другой (например 
такой, как вызов подпрограммы). Замененная ин- 
струкция передает управление блоку команд, состав- 
ляющих главное тело подпрограммы-вируса, которая 
присоединяется к концу программы. Затем к концу 
добавленной подпрограммы присоединяется инструк- 
ция, возвращающая управление “зараженной" про- 
грамме, на инструкцию, следующую за вставленной. 

Таким образом, когда выполняется подпрограмма- 
вирус, выполняется также и подмененная инструкция 
зараженной программы. Исходная программа работает 
так, будто ничего особенного не произошло. Однако, 
на самом деле, подпрограмма-вирус воспользовалась 
каким-то мгновением, чтобы захватить власть над 
средствами операционной системы и прицепить свою 
копию к еще одной программе, хранящейся на диске. 

Приведенный пример демонстрирует лишь один из 
приемов, используемых авторами вирусов. В насто- 
ящее время специалисты выделили и другие приемы, 
отличающиеся друг от друга идеями и изощренностью 
выполнения. 

В широком потоке литературы по проблеме вирусов, 
хлынувшей на нас в последнее время, приводится 
множество классификаций и описаний вирусов. Так 
что интересующихся этой проблемой всерьез я с чув- 
ством глубокого облегчения отсылаю к специальным 
публикациям, большей частью, правда, далеких от со- 
вершенства и законченности. 

2.8 Как возникают угрозы 

Все рассмотренные выше виды опасных програм- 
мных приемов иногда обозначают единым терми- 
ном — “электронные ловушки". 

Заслуживает внимания вопрос о том, как эти ло- 
вушки появляются. 

В простейшем случае программист с самого начала 
разработки программы предусматривает наличие в ней 
какой-либо электронной ловушки, предположим тро- 
янского коня. Скомпилировав программу, он отдает 
свое изделие для использования в вычислительный 
центр или другому пользователю, не предоставляя при 
этом исходного кода программы. Анализировать дво- 
ичный код программы — дело весьма непростое, на 
несколько порядков более сложное, чем анализ текста 
программы на одном из языков программирования 
(хотя и исходный текст можно основательно запу- 
тать). Поэтому весьма велика вероятность того, что 
программа сразу поступит в эксплуатацию, чего, соб- 
ственно, захватчику и нужно. 

Зная о такой нехитрой технике обмана, многие 
центры принимают для обработки лишь исходные тек- 
сты программ. При этом компиляция и эксплуатация 
программы происходит в самом вычислительном цен- 


тре, но только после анализа на наличие в программе 
электронных ловушек. Конечно, непременным усло- 
вием для установления такой дисциплины является 
наличие в составе сотрудников центра высококлас- 
сного программиста, способного выполнить анализ 
исходного кода программы. 

Еще раз отмечу, что поиск электронной ловушки по 
исходному тексту — очень непростая задача. Не стоит 
считать захватчика наивным: можно не сомневаться, 
что он предпримет все, чтобы тщательно замаскиро- 
вать опасный код. Во всяком случае не ждите, что 
текст ловушки будет выделен комментарием типа: 
“Здесь приготовлен сюрприз!". 

Существует много способов затруднить чтение про- 
граммы. Например, можно отбросить всякие правила 
структурного программирования и поступить прямо 
противоположным образом — начать активно исполь- 
зовать в программе переходы из одной части в другую. 
Такие перескоки по тексту очень утомляют при чте- 
нии, поскольку трудно при этом не сбиться и не поте- 
рять смысл алгоритма. 

Далее, существует немало способов вызова подпрог- 
рамм, одна из которых и может оказаться ловушкой. 
Вызов может осуществляться одной командой — по- 
пробуйте выделить эту команду среди- десятков, а то и 
сотен других команд. Кроме того, вызов может быть и 
неявным: например, путем прямого занесения в счет- 
чик команд адреса точки входа ловушки. В других си- 
стемах это можно сделать путем установки указателя 
системного стека на соответствующую команду и т.д. 
Степень изощренности зависит от квалифицированно- 
сти захватчика. 

Если все же ловушка не выделена в некоторую са- 
мостоятельную подпрограмму, можно рассредоточить 
код ловушки по всему тексту программы. Код ловушки 
разбивается на пары команд, причем вторая команда 
каждой пары — команда перехода на следующую 
пару. 

Еще пример? Можно запрограммировать ловушку 
таким образом, чтобы она использовала участки кода 
внешней программы, но в определенной последова- 
тельности и с добавлением небольших серий команд, 
разбросанных по всему тексту программы. Сами по 
себе эти добавочные команды могут выполнять внешне 
невинные^ чаще всего бесполезные, с точки зрения 
анализирующего специалиста, действия. Легко ли 
разобраться в таком месиве команд? Как различить, 
где тело полезной программы, а где — раковая опу- 
холь ловушки? 

Кроме того, следует иметь в виду, что захватчик 
может внедрить электронную ловушку в уже прове- 
ренный исходный код программы, находящийся 
внутри центра. Это лишний раз подтверждает необхо- 
димость средств ограничения доступа пользователей к 
различным ресурсам системы, в частности — к тек- 
стам программ. 

К сожалению, злоумышленное внесение кодов элек- 
тронных ловушек в исходный текст программ — не 
единственный способ внедрить ловушку. Захватчиком 
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может- оказаться высококлассный специалист, способ- 
ный ввести код ловушки непосредственно в двоичный 
код программ (а многие вирусы, например, сами обес- 
печивают внедрение своих копий в исполняемые 
образы программ). Работа с двоичным исполняемым 
кодом программы требует весьма высокого уровня под- 
готовки и надлежащих навыков в работе со специаль- 
ными программными средствами — это своего рода 
“высший пилотаж" программирования. Модификация 
двоичного кода может быть выполнена либо во время 
хранения программы на магнитном носителе в проме- 
жутках между ее вызовами, либо даже во время вы- 
полнения непосредственно в памяти машины. 

Следует понимать, что в чистом виде описанные 
выше приемы встречаются достаточно редко. Гораздо 
чаще в ходе атаки используются отдельные элементы 
разных приемов. Например, “логическая бомба" явля- 
ется фактически другой стороной “троянского коня": 
ведь по сути внешняя программа, содержащая 
“логическую бомбу“, является ничем иным, как 
“троянским конем". Вирусы вообще являются квинтэс- 
сенцией всевозможных методов нарушения безопасно- 
сти. Иногда складывается впечатление, что все 
остальные способы атаки появились только для того, 
чтобы обеспечить возникновение компьютерных виру- 
сов. Посудите сами: одним из самых частых и излюб- 
ленных способов распространения вирусов является 
метод “троянского коня". От “логической бомбы" ви- 
русы отличаются только возможностью размножаться 
и обеспечивать свой запуск — так что многие вирусы 
можно считать особой формой “логических бомб“. Для 
атаки системы вирусы активно используют разного 
рода “люки". Реализовывать вирусы могут самые раз- 
нообразные пакости, в том числе и атаку салями. 
Кроме того, успех атаки одного вида часто способ- 
ствует снижению “иммунитета" системы, создает бла- 
гоприятную среду для успеха атак других видов. За- 
хватчики это знают и активно используют указанное 
обстоятельство. 

Все вышесказанное имеет целью подтолкнуть вас к 
закономерному и единственно верному выводу. Бо- 
роться даже с частным видом нарушений безопасно- 
сти — электронными ловушками — как и с любыми 
другими видами нарушений, можно, только используя 
в комплексе все физические, логические и организа- 
ционные средства и методы обеспечения безопасности. 

3. Безопасность 
в операционных системах 

Операционная система — “душа“ любой компью- 
терной системы — в принципе является очень боль- 
шой и сложной программой. Так что многие слабости 
программ, о которых шла речь выше, присущи и опе- 
рационным системам. 

Однако есть ряд качеств, которые заставляют выде- 
лить вопросы обеспечения безопасности операционных 
систем в особую категорию. 


Прежде всего операционная система часто содержит 
ряд встроенных механизмов, прямо или косвенно 
влияющих на безопасность всех программ и данных, 
работающих и обрабатываемых в среде данной опера- 
ционной системы. 

Помимо этого, размер и сложность операционной 
системы как программы делает качественно более 
сложной атаку на поражение операционной системы. 

Чтобы испортить настроение администратору си- 
стемы, вовсе не обязательно специально разрабатывать 
одну из описанных выше электронных ловушек. Нане- 
сти серьезный ущерб системе — и тем самым нару- 
шить ее безопасность — можно и с помощью самых 
обычных программ или утилит. Например, удалить 
важный для кого-то файл можно с помощью одной 
команды операционной системы. Можно вообще 
отформатировать все доступные носители с помощью 
стандартной системной утилиты, уничтожив тем са- 
мым всю хранившуюся на них информацию и даже 
саму систему. Прочитать данные — те, которые вам 
читать не положено, — легче всего с помощью тексто- 
вого редактора. 

Таким образом, мы подошли к одной из централь- 
ных проблем в обеспечении безопасности: проблеме 
несанкционированного (неавторизованного) доступа и 
способам его предотвращения. Вся проблема заключа- 
ется в обеспечении такого порядка работы, при кото- 
ром систему мог бы использовать только тот, кому ее 
разрешено использовать; чтобы каждый законный 
пользователь работал только со “своими" данными и 
не мог исказить, прочитать или удалить из системы 
данные, принадлежащие другому пользователю (если 
на то нет согласия хозяина); чтобы каждый законный 
пользователь мог выполнять только те операции, кото- 
рые ему разрешено выполнять администратором си- 
стемы. 

В самом деле, вполне естественным является стрем- 
ление не допустить работы в системе посторонних 
лиц: вы же не пускаете случайных прохожих в свой 
дом. Не менее естественно желание пользователей 
иметь гарантии, что их личные данные никто по 
ошибке или с умыслом не удалит, не исказит, не про- 
читает и т.д. 

Кроме того, имеет прямой смысл предоставлять 
каждому новому пользователю для начала только са- 
мый необходимый набор средств, без которых он во- 
обще работать не сможет — хотя бы в целях его же 
собственной безопасности. Вы же не даете ребенку 
молоток, справедливо опасаясь, что он попробует им 
шарахнуть по телевизору (или уж, по крайней мере, 
следите за ним). Начинающий пользователь для си- 
стемы представляет не меньшую угрозу, чем ребенок 
для телевизора. По незнанию, неопытности или не- 
осторожности пользователь может сотворить самые 
невероятные вещи: от простого удаления собственных 
данных (ну, с этим-то сталкивался практически каж- 
дый, кто имел дело с компьютером) до приведения в 
неработоспособное состояние всей системы в целом 
либо отдельных ее компонентов. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 


БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 

Словарь терминов 


Ассехз — доступ — 1) в обработке 

данных: взаимодействие между 
субъектом и объектом, обеспе- 
чивающее передачу информа- 
ции между ними; 2) в физи- 
ческой безопасности: возмож- 
ность входа на защищенную 
территорию. 

Ассехх сопігоі — управление досту- 
пом — в сетях или их компо- 
нентах: задачи, выполняемые 
аппаратурой, программным 
обеспечением и администраци- 
ей, с целью отслеживания вы- 
полняемых в системе операций, 
целостности данных, доступа и 
модификаций системных за- 
писей, выполнения пользовате- 
лями идентификации и предос- 
тавление пользователям досту- 
па. 

А ссек регіоб — период доступа — 
временной интервал, в течение 
которого действуют права дос- 
тупа. В основном этот период 
определяется в днях или неде- 
лях. 

АссоипіаЬІІіІу — отслеживаемость — 
возможность для ответственных 
лиц восстанавливать ход нару- 
шения или попытки нарушения 
безопасности информационной 
системы. 

Ассгебііаііоп — аккредитация — авто- 
ризация и санкционирование 
обработки критичных данных в 
операционной среде информа- 
ционной системы или сети. Ре- 
шение об аккредитации выно- 
сится после получения всеми 
лицами из технического персо- 
нала сертификата, подтвержда- 
ющего возможность этих лиц 
работать с защищенными сис- 
темами. При этом предвари- 
тельно должно быть подтверж- 
дено соответствие проекта са- 
мой системы и его конкретной 
реализации набору заранее оп- 
ределенных технических требо- 
ваний. Все эти условия служат 
единственной цели — обеспе- 
чению степени безопасности 
адекватной уровню критичнос- 
ти данных. 

АІІаск — атака — нарушение безопас- 
ности информационной систе- 
мы, позволяющее захватчику 
управлять операционной сре- 
дой. 

Ашііі — контроль — образ действий, 
позволяющий получать незави- 


симый обзор и анализ систем- 
ных записей и активности сис- 
темы с целью установления ее 
текущего состояния безопаснос- 
ти. 

АиШі Ігаіі — след контроля — записи 
о транзакциях, выполняемых в 
системе, которые (записи) в со- 
вокупности документируют ход 
обработки информации в систе- 
ме, что в свою очередь позволя- 
ет проследить (провести трас- 
сировку) его вперед — от ис- 
ходных транзакций до создава- 
емых в процессе их работы за- 
писей и/или отчетов — а так- 
же назад — от конечных запи- 
сей/отчетов до исходных транз- 
акций. Последовательность за- 
писей, составляющих след кон- 
троля, позволяет определить 
источники возникновения 

транзакций в системе и после- 
довательность их выполнения 
системой. 

АисІШпв — ведение контроля — про- 
цедуры управления системой, 
необходимые для обеспечения 
нормальной работы системы и 
выполнения имеющихся задач, 
а также для обеспечения эф- 
фективности работы и эффек- 
тивности использования ресур- 
сов информационной системы. 
Ведение контроля может осу- 
ществляться лицами, отличны- 
ми от лиц, непосредственно от- 
вечающих за работу системы и 
решение конкретных задач. 

Аииіеп(ісд(іоп — аутентификация — 
1) процедура идентификации 
или проверки полномочное™ 
узлов, инициаторов или лиц 
для доступа к определенной ка- 
тегории информации; 2) план, 
разрабатываемый для обеспече- 
ния защиты от незаконных пе- 
редач информации за счет ус- 
тановления санкционированно- 
сти потоков информации, сооб- 
щений, узлов или инициаторов. 

АиіЬогігаііоп — авторизация — пол- 
номочия, устанавливаемые ад- 
министратором системы для 
конкретных лиц, позволяющие 
последним использовать транз- 
акции, процедуры или всю сис- 
тему в целом. 

Соттипісаііопх хесиліу — безопас- 
ность коммуникаций — аутен- 
тификация телекоммуникаций 
за счет принятия мер по пред- 


отвращению предоставления 
неавторизованным лицам кри- 
тичной информации, которая 
может быть выдана системой в 
ответ на телекоммуникацион- 
ный запрос. 

Сотрготіхе — компрометация — уте- 
ря критичной информации, ли- 
бо получение ее неавторизован- 
ными для этого субъектами 
Спицами,- программами, про- 
цессами и т.д.) 

Сотриіег хесиліу — компьютерная 
безопасность — комплекс тех- 
нологических и административ- 
ных мер, применяемых в отно- 
шении аппаратных средств, 
программ, данных и служб с 
целью обеспечения доступно- 
сти, целостности и конфиден- 
циальности связанных с ком- 
пьютерами ресурсов; сюда же 
относятся и процедуры провер- 
ки выполнения системой опре- 
деленных функций в строгом 
соответствии с их запланиро- 
ванным порядком работы. 

СопЛбепііаІііу — конфиденциаль- 
ность — некоторая классифи- 
кация данных, получение либо 
использование которых неавто- 
ризованными для этого лицами 
может стать причиной серьез- 
ного ущерба для организации. 

Сохі-ЬепеПі апаіухіх — анализ за- 
трат/ іыгоды — стадия в раз- 
работке или развитии системы, 
на которой определяется стои- 
мость обеспечения защиты дан- 
ных в информационной систе- 
ме; иногда под этой стоимостью 
подразумевают ущерб, который 
может быть нанесен в случае 
утери или компрометации дан- 
ных, подлежащих защите. 

Соѵегі сЬаплеІ — скрытый канал — 
канал коммуникации, позволя- 
ющий процессу передавать ин- 
формацию путем, нарушаю- 
щим политику безопасности, 
реализуемую в данной системе. 

Оаіа іпіевгііу — целостность дан- 
ных — состояние, при котором 
данные, представленные в ком- 
пьютере, в точности соответст- 
вуют данным в исходных доку- 
ментах и при этом не могут 
быть подвержены неумышлен- 
ным или умышленным искаже- 
ниям или разрушениям. 

Оаіа ргоіесііоп — защита данных — 
средства защиты данных от 
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случайных или умышленных 
нежелательных модификаций, 
разрушений или разглашений. 

Оаіа хесигііу — безопасность дан- 
ных — защита данных от неав- 
торизованных, случайных, 
умышленных или возникших 
по халатности модификаций, 
разрушений или разглашений. 

БаІа хесигііу оГГісег (050) — офицер 
безопасности — лицо, отвеча- 
ющее за обеспечение безопас- 
ности обработки данных в сис- 
теме и за противодействие по- 
пыткам неразрешенного ис- 
пользования данных. 

ООО Сиібеііпех Гог Сошриіег 
$есигі(у — совокупность пра- 
вил, установленных Министерс- 
твом Обороны США (ООО — 
ОераПтепІ оГ Ое(епсе) для оп- 
ределения степени безопаснос- 
ти узлового программного обес- 
печения — операционных сис- 
тем, узловых средств контроля 
доступа и т.д. 

РогтаІ хесигііу роіісу тобеі — фор- 
мальная модель политики без- 
опасности — политика без- 
опасности, выраженная точным 
математическим образом, 

включающим начальное состоя- 
ние системы, способы перехода 
системы из одного состояния в 
другое и определение “безопас- 
ного" состояния системы. 

Наскіпв — неавторизованная попытка 
доступа к базе данных узла. 
Часто этот термин используется 
в отношении лиц, пытающихся 
получить доступ к узловой базе 
данных с удаленного узла за 
счет обхода (обмана) средств 
контроля доступа в сети. 

ІдепііГісаііоп — идентификация — 
процесс анализа персональных, 
технических или организацион- 
ных характеристик или кодов 
для получения (предоставле- 
ния) доступа к компьютерным 
ресурсам. 

Іпіііѵісіиаі ассоипіаЬіІііу — индивиду- 
альный учет — комплекс мер, 
за счет которых идентифика- 
ция пользователя может быть 
использована для определения 
возможности доступа пользова- 
теля к машинам, материалам и 
т.п.; правила предоставления 
пользователю времени, методов 
и режимов доступа. 

ІпГоппаІіоп хесигііу — безопасность 
информации — защита инфор- 
мационных массивов от слу- 


чайных, либо преднамеренных, 
но неавторизованных разглаше- 
ний, модификаций или разру- 
шений, либо невозможность об- 
работки этой информации. 

ІпГогшаііоп хухіеш хесигііу — без- 
опасность информационной 
системы — совокупность эле- 
ментов, необходимых для обес- 
печения адекватной защиты 
компьютерной системы, вклю- 
чая аппаратные/программные 
функции, характеристики и 
средства; операционные и 
учетные процедуры, средства 
управления доступом на 
центральном компьютере, уда- 
ленных компьютерах и теле- 
коммуникационных средствах; 
административные меропри- 
ятия, физические конструкции 
и устройства; управление пер- 
соналом и коммуникациями. 

Іпіевгііу — целостность — состояние, 
в котором данные или програм- 
мы используются установлен- 
ным образом, обеспечивающим 
устойчивую работу системы; 
автоматическое восстановление 
в случае обнаружения системой 
потенциальной ошибки; авто- 
матическое использование аль- 
тернативных компонентов вме- 
сто вышедших из строя. При- 
мером является дублирование 
важных файлов с тем, чтобы в 
случае обнаружения ошибки 
или утери оригинального фай- 
ла использовать его копию. 
Другим примером является 
поддержание двух и более пу- 
тей доступа к устройству хра- 
нения. 

ЬоорЬоіе — дыра, брешь — програм- 
мное или аппаратное упущение 
или недоработка, позволяющая 
обойти процессы управления 
доступом. Синонимами являют- 
ся термины Гаиіі, Павг. 

Машіаіогу ассехх сопігоі — полно- 
мочное управление досту- 
пом — ограничение доступа к 
определенным объектам, уста- 
новленное на основании выяв- 
ленной степени критичности 
информации, содержащейся в 
данном объекте. При этом обес- 
печивается “прозрачность" дан- 
ного объекта для всех неавтори- 
зованных лиц, т.е. объект как 
бы невидим для них. Управле- 
ние является полномочным, по- 
скольку субъект с конкретными 
правами доступа не может пе- 


редавать эти права другому 
субъекту. 

ОЬіесІ — объект — сущность (т.е. за- 
пись, страница памяти, про- 
грамма, принтер и т.д.), содер- 
жащая или получающая ин- 
формацию. Если субъект имеет 
доступ к объекту, он (субъект) 
исходит из того, что объект 
предоставит ему доступ к хра- 
нимой им информации. 

ОЬіесІ ргоіесііоп — защита объек- 
тов — средства защиты объек- 
тов типа сейфов, файлов и 
т.д. — того, что может быть 
выведено из защищенной об- 
ласти (ргоіесіесі агеа). 

ОЬ^есі геихе — повторное использова- 
ние объекта — предоставление 
некоторому субъекту доступа к 
магнитной среде, содержащей 
один и более объектов. Будучи 
доступной для субъекта, маг- 
нитная среда может в то же 
время содержать остатки дан- 
ных от объекта, содержавшего- 
ся на этом месте ранее. 

ОМВА-123 — директива федерального 
правительства, определяющая, 
что при выполнении любыми 
правительственными органами 
или любыми компаниями работ 
для правительства с использо- 
ванием компьютеров подрядчи- 
ки должны составить краткий 
план идентификации и защиты 
ресурсов их информационной 
системы. 

Орегаііопаі баіа хесигііу — операци- 
онная безопасность данных — 
защита данных от модифика- 
ции, разрушения или разгла- 
шения (случайных, неавторизо- 
ванных, либо преднамеренных) 
во время выполнения операций 
ввода, обработки или вывода. 

Огапде Ьоок — “оранжевая книга" — 
полное название “БераПшепІ о( 
ОеГепсе Тгихіед Сошриіег 
$у$Іеш Еѵаіиаііоп Сгііегіа" РСФ 
5200.28-ЗТО (“Критерий оце- 
нивания безопасности компью- 
терных систем министерства 
обороны") — государственный 
стандарт оценивания безопас- 
ности компьютерных систем, 
устанавливающий четыре иера- 
рхических класса — А, В, С и 
О — определенных уровней до- 
веренности (иными словами, 
уверенности в безопасности) 
для конкретных приложений, 
разрабатываемых и используе- 
мых в интересах правительства. 


3 Зак. 2503 
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3.1 Триединая задача защиты системы 

Чтобы не допустить работы с системой какого-либо 
постороннего лица, случайно оказавшегося за терми- 
налом, необходимо обеспечить распознавание систе- 
мой каждого законного пользователя (или, по крайней 
мере, ограниченных групп пользователей). Для этого в 
некотором (желательно, защищенном) месте системы 
обычно заводится файл, куда записывается ряд при- 
знаков каждого пользователя, по которым можно этого 
пользователя опознать. В дальнейшем при входе в си- 
стему, а при необходимости — и при выполнении 
определенных действий пользователь обязан себя 
идентифицировать. 

Идентификация пользователя заключается в том, 
что он при выполнении каких-либо действий должен 
себя назвать, вернее указать идентификатор, присво- 
енный данному пользователю в данной системе. 

Получив идентификатор, система сравнивает его 
значение с эталоном, который хранится в указанном 
выше файле, и, в случае совпадения, обеспечивает 
возможность пользователю работать с компонентами 
системы. 

Следует отметить, что идентификация не обяза- 
тельно состоит во вводе некоторого имени с клави- 
атуры. Для идентификации пользователя могут при- 
меняться (и успешно применяются!) специальные 
устройства, способные идентифицировать 

пользователя по некоторым его физическим 
характеристикам, например по отпечаткам пальцев, 
спектральному составу голоса или даже по сетчатке 
глаза. Кроме того, для идентификации применяются 
различного рода магнитные карточки, специальные 
ключи и т.д. 

После идентификации система обязательно произ- 
водит аутентификацию полученного идентификатора: 
проверяется содержательность указанного идентифи- 
катора для данной системы. В самом деле, требование 
идентификации заключается только во вводе иденти- 
фикатора. А если пользователь в ответ на запрос вве- 
дет какое-нибудь случайное слово, первым пришедшее 
на ум? Если бы идентификация не дополнялась аутен- 
тификацией, то сама идентификация теряла бы вся- 
кий смысл. Часто аутентификация пользователя осно- 
вана либо на запросе ввода пользователем пароля, 
либо на запросе ответов на некоторые тестовые 
вопросы. В любом случае для проведения 
аутентификации пользователь должен выполнить 
некоторые явные действия. Следует отметить, что 
механизмы, используемые для выполнения ау- 
тентификации, должны быть устойчивы к подлогу, 
подбору или подделке. 

После распознавания пользователя современная си- 
стема должна выяснить, какие права предоставлены 
этому пользователю: какие данные он может исполь- 
зовать (читать, писать, модифицировать, удалять); ка- 
кие программы он может выполнять; когда, как долго 
и с каких терминалов он может работать (да, даже 
это!) и другие вопросы подобного рода. Выяснение си- 


стемой всех этих вопросов называется “авторизацией" 
пользователя***. 

Таким образом, выражение “пользователь авторизо- 
ван для выполнения некоторых действий" означает 
только то, что пользователь имеет право (т.е. ему раз- 
решено ответственными лицами компьютерной си- 
стемы) выполнять в системе эти действия. 

Авторизация обязательно приводится при входе 
пользователя в систему (т.е. в самом начале работы 
пользователя с системой). Собственно вход в систему 
практически полностью и состоит в выполнении иден- 
тификации, аутентификации и авторизации. 

Однако в процессе последующей работы пользова- 
теля с системой обычно требуется возможность допол- 
нительной авторизации пользователя в отношении ра- 
боты с конкретными ресурсами или выполнения кон- 
кретных действий. 

В настоящее время существуют самые разные меха- 
низмы реализации разделения доступа. 

Одним из таких механизмов являются так называ- 
емые “списки управления доступом". Смысл их со- 
стоит в том, что каждому ресурсу системы при необ- 
ходимости может быть ^ сопоставлен некоторым 
образом организованный список, в котором указаны 
идентификаторы всех пользователей, которым 
разрешен (или, наоборот, запрещен) доступ к данному 
ресурсу, а также определено, какой именно доступ 
разрешен. При обращении некоторого пользователя к 
данному ресурсу система автоматически проверяет 
наличие у данного ресурса списка управления 
доступом и, если он есть, проверяет, разрешено ли 
данному пользователю работать с данным ресурсом в 
запрошенном режиме. 

В качестве ресурсов могут выступать как отдельные 
объекты системы (файлы, устройства, носители, про- 
граммы и т.д.), так и целые компоненты системы (все 
данные, все устройства или все программы) и даже 
вся система в целом. 

Другим примером реализации механизма авториза- 
ции пользователя могут служить профили пользовате- 
лей. Профиль пользователя — это тоже организован- 
ный некоторым образом список, сопоставленный опре- 
деленному идентификатору пользователя и содержа- 
щий перечень всех объектов, к которым данному поль- 
зователю разрешен доступ, с указанием в каждом слу- 
чае типа разрешенного доступа. 

Существует также механизм, называемый 
“матрицей доступа". Матрица доступа — это некото- 
рая системная структура данных, которую легче всего 
представить в виде таблицы, столбцы которой поме- 


*** Здесь возможна некоторая путаница. Дело в том, что 
процесс проверки прав пользователя по доступу к системе 
называется авторизацией, но и вся совокупность прав 
пользователя также называется авторизацией. Более того, 
иногда под термином авторизация понимается вообще вся 
совокупность “идентификация/аутентификация/авториза- 
ция". 

Конкретный смысл этого термина определяется обычно по 
контексту, в котором этот термин употреблен. 
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чены идентификаторами всех существующих в си- 
стеме ресурсов, а строки — идентификаторами всех 
зарегистрированных в системе пользователей На пе- 
ресечении каждого столбца таблицы с каждой ее стро- 
кой администратором проставляется специальный ука- 
затель разрешенного данному пользователю типа до- 
ступа к данному объекту. 

Общим для перечисленных, а также для ряда дру- 
гих механизмов, обеспечивающих проведение систе- 
мой в нужный момент авторизации пользователя, яв- 
ляется следующее. Во-первых, доступ к данным меха- 
низмам должны иметь только специальные системные 
программы, обеспечивающие безопасность, а также 
строго ограниченный круг персонала системы, отвеча- 
ющего за ее безопасность. Во-вторых, указанные ме- 
ханизмы сами должны быть тщательно защищены от 
случайного или преднамеренного доступа к ним лиц 
или программ, неавторизованных для этого, поскольку 
эти механизмы (данные и обслуживающие их специ- 
альные программы) являются одной из важнейших со- 
ставляющих в обеспечении безопасности системы. 

Многие известные атаки на системы нацелены на 
поражение или обход именно средств разделения до- 
ступа, поскольку они составляют одно из самых су- 
щественных препятствий на пути любого захватчика. 

3.2 Общесистемные экспозиции 

Помимо того, что сами системные программы могут 
быть нашпигованы самыми различными видами элек- 
тронных ловушек, описанных выше, существует целый 
ряд методов проведения атак на безопасность системы 
в целом с целью получения доступа к отдельным ее 
компонентам. Приведем примеры таких методов: 

1. ВЕТАУЕЕЫ ЬШЕЗ (между строк) — подключение 
к линиям связи и внедрение в компьютерную систему 
с использованием промежутков в действиях законного 
пользователя. Дело в том, что при интерактивной ра- 
боте терминал большую часть времени простаивает: 
пока пользователь обдумывает что-либо, набирает ко- 
манду, читает выведенную информацию и т.д. Эти 
“окна“ вполне могут быть использованы для работы с 
системой кого-либо под маской пользователя. 

2. ТКАРРІС АЫАЬѴЗІЗ (анализ трафика) — за-, 
хватчик анализирует частоту и методы контактов 
пользователей в системе. При этом вполне можно вы- 
яснить правила вступления в связь, после чего произ- 
водится попытка вступить в контакт под видом закон- 
ного пользователя. 

3. иЫЕ ЭІЗССЖЫЕСТ (разрыв линии) — пользо- 
ватель выходит из системы, либо захватчик разрывает 
линию, но система об этом не догадывается и продол- 
жает работу с захватчиком как с законным пользова- 
телем. 

4. МА5(}1)ЕКАОЕ (маскарад) — захватчик исполь- 
зует для входа в систему ставшую ему известной иден- 
тификацию законного пользователя. 

5. РІССѴВАСК (свинство, или “подкладывание 
свиньи") — захватчик подключается к линии связи и 


имитирует работу системы с целью получения инфор- 
мации об идентификации пользователя. Например, он 
может имитировать зависание системы и процедуру 
повторного входа в нее. Пользователь, не подозревая 
об этом, вводит свою идентификацию и пароль, после 
чего захватчик просто возвращает ему управление 
нормально работающей системой. 

Особо следует остановиться на такой не слишком 
известной пользователям экспозиции системы, как 
“повторное использование объектов". 

Чтобы понять смысл этой опасности, следует вспо- 
мнить, что когда, например, операционная система 
сообщает вам о том, что по вашему желанию некото- 
рый файл удален, то это вовсе не означает, что со- 
державшаяся в данном файле информация уничто- 
жена в прямом смысле слова. Удаление файла озна- 
чает только то, что система пометила блоки памяти, 
ранее составлявшие содержимое файла, специальным 
флажком, говорящим о том, что данный блок не вхо- 
дит в состав какого-либо файла и может быть поэтому 
использован для размещения в нем какой-то инфор- 
мации. Но та информация, которая была записана в 
данном блоке раньше, никуда не исчезает! То есть, 
если прочитать сам блок (а это вполне можно сде- 
лать), то можно беспрепятственно получить доступ к 
“удаленной" информации! 

Описанная стратегия “удаления" по ряду вполне 
объективных причин используется в подавляющем 
большинстве компьютерных систем. Причем в каче- 
стве объекта атаки могут фигурировать не только 
блоки файлов, но и различного рода буферы, кадры 
страниц памяти, секторы магнитных дисков, зоны 
магнитных лент, регистры памяти и т.д. 

Вполне логичным представляется то, что описанная 
выше стратегия удаления (а вернее всего — сохране- 
ния, как это ни парадоксально звучит!) провоцирует 
различного рода захватчиков на попытки считывания 
остатков информации прямо из памяти машины. Для 
этого в ряде случаев бывает достаточно создать не- 
большую программку, запрашивающую во время вы- 
полнения динамического выделения дополнительной 
памяти достаточно большого объема. Затем в резуль- 
тате умышленной ошибки эта программа может ава- 
рийно завершаться с выдачей так называемого 
“посмертного" дампа, представляющего собой длин- 
ную распечатку в шестнадцатиричном представлении 
содержимого всех областей памяти, используемых 
“свалившейся" программой. Читать такую распечатку, 
тем более искать в ней что-либо без специальных на- 
выков сложно, поэтому рядовой оператор может и не 
понять, что буквально на его глазах осуществляется 
кража информации. 

Весь смысл такой программки состоит в том, чтобы 
захватить в свое распоряжение как можно больше 
областей памяти, только что использованных про- 
граммой, обрабатывавшей критичную информацию, в 
надежде извлечь из них остатки этой критичной 
информации. Конечно, вероятность выделения про- 
грамме-захватчику именно тех областей, которые со- 
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держат остатки интересующей захватчика информа- 
ции, достаточно мала. Однако такая вероятность су- 
ществует, особенно если программу-захватчика запу- 
стить сразу же по завершении работы программы, 
обрабатывавшей критичную информацию. 

В конце концов, получить дамп интересующих 
областей памяти можно и с использованием ряда 
стандартных системных утилит — и это лишний раз 
доказывает необходимость ограничения доступа поль- 
зователей даже к обычным средствам системы. 

Борьба против атак такого рода заключается в 
устранении возможности считать остатки информа- 
ции. Делается это либо полным затиранием остатков 
информации или заполнением их какой-либо бес- 
смыслицей (в простейшем случае — просто блоком 
сплошных нулей или единиц), либо — более тонко — 
путем отказа любому пользователю в возможности 
прочитать “свободный“ блок до тех пор, пока этот 
пользователь полностью не заполнил его своей соб- 
ственной информацией. 

В настоящее время ряд операционных систем изна- 
чально содержат встроенные средства блокировки 
“повторного использования". Для других типов опера- 
ционных систем существует достаточно много коммер- 
ческих программ, не говоря уже о специальных паке- 
тах безопасности, реализующих аналогичные фун- 
кции. 

3.3 Четыре базовых средства 

обеспечения безопасности 

Существуют четыре универсальных метода защиты 
и противодействия нарушениям безопасности компью- 
терных систем. 

Первый метод — шифрование данных. Шифрова- 
нием называется некоторое обратимое однозначное 
преобразование данных, делающее их непонятными 
для неавторизованных лиц. Шифрование насчитывает 
тысячелетнюю историю, во всяком случае имеются 
сведения, что к шифрованию донесений прибегали 
еще древнегреческие полководцы. Чтобы получить на- 
глядный пример шифрования, советую вам прочитать 
рассказ Конан Дойля “Пляшущие человечки" о Шер- 
локе Холмсе или роман Жюля Верна “Граф Матиас 
Шандор". Помимо названных произведений суще- 
ствует также масса специальной литературы по дан- 
ному вопросу. 

Специалисты считают, что шифрование является 
одним из самых надежных средств обеспечения безо- 
пасности данных. В самом деле, охота за данными в 
компьютерных системах во многом обусловлена тем, 
что слишком многие люди, не имеющие сколь-нибудь 
специального образования, способны разобраться, как 
использовать Эти данные в своих личных интересах. 
Но(!) все это имеет смысл лишь при условии, что 
сами данные представлены в понятном виде, например 
в виде строки текста на некотором естественном 
языке. Однако стоит произвести несложную манипу- 
ляцию — провести однозначную замену одних симво- 


лов (допустим, букв) на другие символы (допустим, 
цифры в сочетании со специальными символами) как 
чтение той же строки текста будет весьма серьезно за- 
труднено. 

Метод защиты информации шифрованием подразу- 
мевает обязательное выполнение следующих требова- 
ний. Никто, кроме хозяина данных и лиц, которым 
разрешен доступ к этим данным, не должен знать, 
во-первых, самого алгоритма преобразования данных, 
а, во-вторых, управляющих данных для такого алго- 
ритма — так называемых ключей. 

Доступ к зашифрованным данным обязательно 
включает этап расшифровки данных — т.е. выполне- 
ния обратного преобразования данных из непонятного 
в понятное представление. 

Шифрование делает почти бессмысленным простой 
доступ к данным: ведь, не зная ключа, захватчик мо- 
жет годами биться над украденной абракадаброй, но 
так и не понять смысла данных. Кроме того, шифро- 
вание имеет еще одно немаловажное в смысле безо- 
пасности свойство. Расшифровка возможна только в 
том случае, когда зашифрованные данные не были 
искажены. Искажение зашифрованных данных в сиду 
однозначности преобразования неминуемо повлечет 
искажение данных, получаемых в результате расшиф- 
ровки. Таким образом, если захватчик как-либо иска- 
зил (модифицировал) зашифрованные данные, то 
факт нарушения безопасности будет выявлен при пер- 
вой же попытке расшифровки, поскольку в расшифро- 
ванных данных появятся искаженные участки. 

Это свойство особенно полезно для предотвращения 
искажений программ. Код программы шифруется с 
тем, чтобы быть расшифрованным только на в рюмя 
выполнения программы. Если в промежутке между 
выполнениями программы .ее зашифрованный код 
исказить, то после расшифровки программа в 
большинстве случаев работать не будет. Хотя и есть 
некоторая вероятность случайного искажения 
зашифрованного кода таким образом, что программа 
все же будет работать, однако вероятность эта очень 
мала. Еще меньше вероятность успешного выполнения 
целенаправленного изменения зашифрованного кода 
программы, например, с целью вставить в нее одну из 
ловушек. 

В идеале данные в расшифрованном виде должны 
существовать только во время их законной обработки 
владельцем и быть зашифрованными во всех других 
случаях — при хранении, пересылке по линиям связи 
и т.д. Однако такое тотальное шифрование суще- 
ственно снижает эффективность системы, так как ее 
значительные ресурсы отвлекаются на выполнение 
операций шифрования/расшифрования. Приемлемый 
вариант обычно достигается путем определения для 
такого способа защиты ограниченного количества 
данных, требующих наиболее высокого уровня 
защиты. 

Второе универсальное средство защиты — регуляр- 
ное создание резервных копий системы- целиком или 
ее наиболее важных компонентов. 
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Имея в запасе резервную копию и столкнувшись с 
искажением ваших данных или их потерей, вы просто 
извлекаете копию утерянных данных и продолжаете 
нормальную работу. Даже если с момента создания 
резервной копии до момента утери данных прошло 
некоторое время, в течение которого вы вносили в эти 
данные какие-либо изменения, наличие резервной ко- 
пии значительно облегчит вам восстановление данных, 
поскольку проще восстановить внесенные изменения, 
чем заново подготовить все данные -целиком. 

Полезность резервного копирования и его важность 
трудно переоценить. Наличие резервных копий 
(лучше всего — нескольких, хранимых в разных ме- 
стах) обезопасит вас от многих неприятностей. В 
частности, наличие резервной копии системы — уни- 
кальный по универсальности способ борьбы с компью- 
терными вирусами. Многими центрами принято хра- 
нить три последних копии системы по схеме “дед- 
отец-сын“. Кроме того, важным считается установле- 
ние определенной дисциплины и порядка копирова- 
ния. Нарушение этой дисциплины карается не менее 
серьезно, чем любое нарушение безопасности. 

Конечно, создание и хранение резервных копий 
требует определенных затрат ресурсов системы, равно 
как и значительного терпения ответственных за копи- 
рование лиц. Но, во-первых, все затраты с лихвой 
окупаются за счет обеспечения безопасности системы, 
а, во-вторых, в современных системах существует не- 
мало средств, специально предназначенных для созда- 
ния резервных копий и существенно облегчающих вы- 
полнение копирования. 

Третье средство предупреждения неприятностей — 
наличие так называемого следа контроля. Для любого 
захватчика серьезным поводом подумать о целесооб- 
разности атаки служит факт наличия в компьютерной 
системе средств осуществления контроля. Контроль 
системы заключается в выделении, накоплении в еди- 
ном месте (так называемом “следе контроля"), защи- 
щенном хранении и предоставлении по требованию 
авторизованного (для выдачи такого требования) поль- 
зователя специальных данных о различных типах со- 
бытий, происходящих в системе и так или иначе вли- 
яющих на состояние безопасности данной компьютер- 
ной системы. 

След контроля не тождествен контрольному жур- 
налу; контрольный журнал — всего лишь частный вид 
реализации следа контроля. По определению след 
контроля — это совокупность записей, содержащих 
требуемую контрольную информацию, представлен- 
ную в установленном формате. Таким образом, след 
контроля может быть реализован в виде специальной 
области памяти, доступ к которой может быть осу- 
ществлен исключительно средствами подсистемы кон- 
троля, либо в виде отдельного устройства, опять же 
защищенного от незаконного доступа со стороны неав- 
торизованных для этого пользователей. 


Контроль системы преследует в основном две цели. 
Он служит: 

a) для отслеживания текущего состояния безопасности 
в защищаемой системе, своевременного обнаружения 
возможности нарушения безопасности и предупреж- 
дения об этом лиц, отвечающих за безопасность си- 
стемы; 

b) для обеспечения возможности обратной трассировки 
(по данным контроля) происшедшего нарушения 
безопасности с целью обнаружения причин данного 
нарушения и установления степени ответственности 
причастных к нарушению лиц. 

Четвертое средство — использование избыточных 
данных. В некотором смысле резервная копия — част- 
ный случай избыточных данных. Но Не единственный. 

Например, часто практикуется хранение в некото- 
ром защищенном месте системы так называемых риг- 
натур важных объектов системы. 

Например, для файла в качестве сигнатуры может 
быть использовано сочетание байта защиты файла с 
его именем, длиной и датой последней модификации. 
При каждом обращении к файлу или в случае возник- 
новения подозрений текущие характеристики файла 
сравниваются с эталонными. Расхождение каких-то 
характеристик свидетельствует о возможной модифи- 
кации файла (например, может увеличиться или 
уменьшиться длина файла). 

Другим примером избыточных данных является 
применение контрольных сумм, контроль данных на 
чет-нечет, помехоустойчивое кодирование и т.д. В лю- 
бом случае применение избыточных данных направ- 
лено на предотвращение появления в данных случай- 
ных ошибок и выявление неавторизованных модифи- 
каций. 

И. Моисеенков 
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ИНСТРУМЕНТАЛЬНЫЙ КОМПЛЕКС 

ДЛЯ РАЗРАБОТКИ ПРИЛОЖЕНИЙ С ГРАФИЧЕСКИМ ИНТЕРФЕЙСОМ 

’ТРАФИН-П” 


Если Вы — прикладной программист, занятый разработкой информационных систем на 
ПЭВМ, то ”ГРАФИН-И” — это инструмент для Вас! 

Инструментальный комплекс "ГРАФЙН-П” придаст выразительность и наглядность Вашим 
приложениям за счет оснащения их графическим интерфейсом. Он поможет Вам в создании 
автоматизированных рабочих мест (АРМов), информационно-справочных, обучающих систем 
и т.п., требующих использования графического интерфейса в сочетании с возможностью 
ведения баз данных с графическими типами данных. 

"ГРАФИН-11” — ЭТО: 

- графические типы данных в базе данных приложения (растровые образы, пиктограммы, 
векторные типы — точка; линия, контур, область); 

- графический многооконный (подобный М8 ^Ѵіпболѵз ѵ. 3.0) интерфейс пользователя 
(графическая интерпретация объектов предметной области в сочетании с пиктографическими 
и текстовыми позиционными меню), включая полную поддержку манипулятора "мышь”, 
диджитайзера, системы сенсорного ввода ТоисЬВсгееп, лазерных и матричных принтеров. 

’ТРАФИН-П” — это инструмент прикладного программиста, позволяющий ему создать для 
пользователя различные приложения с графическим интерфейсом: 

- информационно-справочные; 

- обучающие; 

- картографические; • 

- и ар. системы. 

Основой комплекса ”ГРАФИН-ІІ” является Графический Процессор, представленный в виде 
объектной библиотеки, включающей около 100 функций и расширяющей Вашу систему 
программирования: Сііррег (версии 5.01 или 8шшпег’87) или МісгозоН С (версии не ниже 
5.0). 

Геореляционный Процессор ”ГРАФИН-П” позволяет поддерживать графические типы 
данных, расширяющие стандартный набор типов данных Сііррег, либо другой СУБД. 

Для Сііррег 5.01 "ГРАФИН-П” включает надстройку, расширяющую язык командами работы 
с Графическим и Гео реляционным Процессорами, а также эмуляцию стандартной 
подсистемы ввода/вывода Сііррег в графической среде ”ГРАФИН-П”. 

В состав комплекса "ГРАФИЙ-11” входят также: 

- Универсальная Драйверная система поддержки многоязычной среды. 

- Редактор Пиктограмм, 

- Генератор Графического Диалога, 

- Библиотека Функций Конструирования Графического Интерфейса, 

- Растровый Графический Редактор, 

- Редактор Шрифтов, 

которые помогут Вам быстро и удобно включить элементы графического интерфейса в свои 
приложения. Все компоненты комплекса снабжены исчерпывающей, включающей много 
примеров, хорошо структурированной документацией (на русском/английском языках). 
Поставка содержит также встроенную документацию (Могіоп Сиійе) и комплект 


Поставка содержит также встроенную документацию (ічогхоп Сшае) и комплект 
контрольных примеров с исходными текстами. 

"ГРАФИН-П” понимает формат графического редактора РаіпЬЬгизЬ (фирма 2зоН), — Вы 
можете создавать в нем собственные изображения, либо редактировать изображения, 
введенные со сканера/видеокамеры. 

Комплекс работает в среде РС ІЮ8 (М8 ЕЮ8) версии не ниже 2.1 на ПЭВМ ІВМ РС/ХТ, АТ, 
АТ-386, Р8/2 и совместимых. Необходимо наличие графического дисплея и адаптера, 
совместимого с ІВМ ССА/ЕОА/ѴСА/МСОА. Эффективно поддерживается манипулятор 
"мышь”, совместимый с МісгозоН Моизе, диджитайзер, а также система сенсорного ввода 
ТоцсЬЗсгееп. Для ведения значительных по объему графической информации баз данных 
необходим жесткий диск. Графические образы могут быть введены со сканера/видеокамеры. 
Вы также можете получить твердую копию на матричном/лазерном принтере. 

С использованием комплекса ”ГРАФИН-ІІ” нами разработаны информационно-справочные 
системы "ГОРОД” "ЯРМАРКА” и ряд демонстрационных примеров, которые мы готовы Вам 
показать, а также ответить на все Ваши вопросы, если Вы обратитесь по адресу: 

СОВЕТСКО-АМЕРИКАНСКОЕ СОВМЕСТНОЕ ПРЕДПРИЯТИЕ 
"Инновационные Информационные Технологии” (ИНИТ) 

252004, Киев-4, ул. Красноармейская, 236 
Телефон: (044) 224-05-74 Факс: (044) 228-27-97 
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вероятно, трудно найти в нашей 
стране пользователей персонального 
компьютера, которому совершенно не 
известно, что такое РС Тооіз, хотя 
этот популярный программный продукт 
рассчитан на более или менее 
подготовленного пользователя, уже 
чувствующего себя профессионалом. 


РС Тооіз 7.0 - 

интегрированный 

профессиональный инструментарий 


Изготовитель пакета РС Тооіз, американская фирма 
Сепігаі Роіпі ЗоПтѵаге, входит в число мировых техно- 
логических лидеров по производству программ. Эта 
фирма только что официально объявила о завершении 
работ над новейшей версией пакета — РС Тооіз 7.0. 
Сепігаі Роіпі 8о11\ѵаге утверждает, что этот новый па- 
кет утилит пока является единственным на рынке ин- 
струментальным средством, идеально подходящим для 
всех пользователей персональных компьютеров, кото- 
рые используют в своих машинах новую версию 008 
5.0 или Шіпйоіѵз 3.0. 

Благодаря безусловному успеху предыдущей версии 
РС Тооіз 6.0 не только окрепла всемирная слава 
Сепігаі Роіпі ЗоІПѵаге как фирмы, следующей в ногу с 
прогрессом в информационных высоких технологиях, 
но и существенно возросли прибыли от реализации 
программных средств. По известным данным, опубли- 
кованным в прессе, доходы фирмы Сепігаі Роіпі 
ЗоНѵѵаге увеличиваются по меньшей мере на 50% 
ежегодно. Всем известно, что на Западе рынок любых 
продуктов информационной технологии в очень боль- 
шой степени зависит от паблисити, и поэтому он тес- 


но связан с отзывами и оценками на страницах веду- 
щих компьютерных журналов. Тем самым многочис- 
ленные компьютерные журналы давно уже преврати- 
лись в органическую часть рынка программ и 
всевозможного компьютерного “железа", ибо страницы 
журналов — это и есть грандиозная витрина этого 
рынка. Если новый продукт не будет положительно 
отмечен на страницах компьютерных журналов, 
рассчитывать на успешный маркетинг и продвижение 
этого товара на рынок практически невозможно. 

В 1990 году пакет РС Тооіз 6.0 получил высочай- 
шую оценку экспертов редакции журнала РС Ма§а- 
гіпе, почетный приз журнала ІпІо'ѴѴогШ за лучший 
продукт 1990 года под названием “Ргойисі о! ТЬе 
■Уеаг“ , приз журнала РС ЛѴогІсі “1990 \Ѵогс1 Сіазз 
Аѵагб“ и множество других призов, наград и востор- 
женных рецензий, продолжающих появляться на стра- 
ницах почти всех компьютерных периодических изда- 
ний мира. Например, журнал ВѴТЕ только что сооб- 
щил в июльском номере, что пакет РС Тооіз Оеіихе 
6.0 завоевал приз читательских симпатий “1991 
Кеабег'з СЬоісе А\ѵагсі“. 
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Расположенный в Мюнхене филиал фирмы Сепігаі 
Роіпі 5оНѵѵаге ОеиІзсЫапё СтЬН любезно предоставил 
нам для ознакомления бета-копию новейшей версии 
РС Тооіз 7.0, чтобы заблаговременно оценить ее и 
проинформировать наших читателей о возможностях 
этой “интегрированной группы утилит", как называют 
этот пакет сами изготовители. Исследование бета-вер- 
сии РС Тооіз 7.0 осуществили сотрудники малого 
предприятия “Такт“. Знакомство с новой бета-версией 
любой программы, словно генеральная репетиция 
спектакля, обычно не предназначена для публичного 
обсуждения обнаруженных недостатков. Поэтому здесь 
вы сможете узнать только лишь одни хорошие ново- 
сти, характеризующие лучшие стороны нового про- 
граммного продукта, а критические замечания о РС 
Тооіз 7.0 мы сможем высказать позже, проанализиро- 
вав уже готовое изделие. 

Новая версия РС Тооіз 7.0 имеет целый ряд после- 
довательных усовершенствований по сравнению с РС 
Тооіз 6.0. Помимо дюжины новых функций и свыше 
сотни улучшений в работе прежних функций, в этой 
версии предусмотрена возможность работы как под 
управлением 005, так и в графической среде ^іпбочѵз 

3.0, Выполнение многих функций РС Тооіз 7.0 пре- 
восходно дополняет новую операционную систему 005 

5.0, так как создатели пакета стремились к полнейшей 
программной совместимости и комплиментарности с 
005 5.0. РС Тооіз 7.0 автоматически поддерживает 
новую возможность 005 5.0 размещаться в “верхней 
памяти'*, освобождая тем самым большую часть 
основной оперативной памяти для размещения при- 
кладных программ. С утилитами РС Тооіз 7.0 совме- 
стима и новая оболочка 005 5.0 5Не11, используя ко- 
торую вместо оболочки РС5Ье11, входящей в РС Тооіз 

7.0, можно успешно применять многие утилиты РС 
Тооіз 7.0 для восстановления, резервного копирования, 
поиска и просмотра файлов разных форматов. 

Кроме того, РС Тооіз 7.0 имеет развитую поддер- 
жку для работы в локальной сети под Ыоѵеіі ЫеОѴаге. 
При работе РС Тооіз 7.0 под 005 на экране 
возникает весьма удобный и визуально очень похожий 
на АѴіпботѵз графический интерфейс пользователя, 
соответствующий получающему все более широкое 
распространение стандарту ІВМ СЧА ( Соштоп ІІзег 
Ассезз ). Существенно облегчает работу с РС Тооіз 7.0 
и мощная система контекстной гипертекстовой 
справки. Быстро и легко перемещаться внутри этой 
разветвленной Ьеір-системы позволяет гипертекст: 
указав мышью выделенные слова или понятия и лишь 
щелкнув кнопкой, вы мгновенно переходите к более 
глубокой и подробной информации следующего 
уровня. Все команды в РС Тооіз 7.0 можно вводить и 
в командной строке, но едва ли пользователи станут 
пренебрегать эффектной и удобной системой меню. 
Специальная система изменения конфигурации и 
расцветки меню показалась нам даже чрезмерно 
богатой альтернативами. Можно незаметно для себя 
потратить уйму времени, подбирая и экспериментируя 
со всевозможными вариантами оттенков меню. 


надписей и опций. Слишком обширный выбор может 
поставить в тупик пользователя, воспитанного в среде 
нашего извечного дефицита! 

Пожалуй, едва ли можно назвать “хорошей ново- 
стью“ то, что новая версия РС Тооіз 7.0 оказалась, 
увы, еще менее компактной, чем предыдущая. Но это 
можно уже признать вполне естественной тенденцией 
в развитии современного программного обеспечения, 
которое явно не желает равняться на бедные техни- 
ческими возможностями персональные компьютеры, 
каких в нашей стране подавляющее большинство. По- 
лученная нами бета-копия РС Тооіз 7.0 занимает 8 
дискет по 720 Кбайт, причем часть программ на этих 
дисках помещена в сжатом виде. При инсталляции 
полного набора утилит РС Тооіз 7.0 для использова- 
ния под 005 требуется 5,9 Мбайт свободного про- 
странства на жестком диске. Если вы собираетесь 
использовать ее в качестве приложения для Ѵ/іпбоѵз 

3.0, потребуется только 1,9 Мбайт дискового простран- 
ства, помимо около 5 Мбайт, занимаемых АУіпскнѵз. 
Кроме того, при работе под 005 необходим минимум 
640 Кбайт памяти, а для использования РС Тооіз 7.0 
вместе с МісгозоН >Ѵіпбо\ѵз 3.0 нужно иметь не менее 
2 Мбайт оперативной памяти. Такие технические тре- 
бования могут кому-то показаться чрезмерно же- 
сткими и отсекающими часть рынка более “слабых" 
персональных компьютеров. Но воспринимать это 
можно и как заявку на рынки сбыта в будущем, когда 
через пару лет возможности средних стандартных пер- 
сональных компьютеров наверняка станут обгонять 
нынешние высшие достижения. 

Приводимый ниже краткий обзор возможностей 
многочисленных утилит, составляющих новую РС 
Тооіз 7.0, показывает, что многие из них существенно 
не изменились в сравнении с предыдущей версией. 
Это вполне соответствует известной концепции марке- 
тинга программных продуктов, которая гласит: 
“торопись медленно**, то есть в каждой последующей 
версии программы должна сохраняться логическая 
преемственность с предыдущими версиями. Несо- 
мненно, эта заповедь в РС Тооіз 7.0 свято соблюдена, 
и те пользователи, которым уже знакомы предыдущие 
версии, смогут без труда адаптироваться к переменам 
и новшествам новой версии. 

Резервное копирование жесткого диска 

в Б08 и 1Уіп(1о\ѵ$ 

Утилита Васкир включает полную совместимость 
данных и полную идентичность манипуляций клави- 
шами при использовании приложений под 405 и 
АУіпбоѵз. Новый очень выразительный интерфейс 
пользователя внешне очень похож как для 005, так и 
для >Ѵіпбоѵз. 

Резервное копирование может осуществляться в фо- 
новом режиме в процессе работы в приложениях \Ѵіп- 
<1о\ѵз. Возможно использование автоматического ре- 
жима выполнения резервного копирования по установ- 
ленному графику. Поддерживается широкий перечень 
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различных устройств для резервного копирования на 
гибкие и жесткие диски, на кассеты Бернулли и на 
стримеры формата (}ІС-40/80 и Ігѵіп. Допустимо ре- 
зервное копирование записей длиной до 250 Мбайт на 
кассету с магнитной лентой. Скорость передачи дан- 
ных — до 7 Мбайт/мин при записи на магнитную 
ленту и до 3,5 Мбайт/мин при записи на гибкие 
диски или другие устройства 008. При этом данные 
могут сжиматься до 60% для экономии места на носи- 
телях со снижением скорости записи. 

В целях повышения надежности перед записью 
осуществляется верификация носителя резервной ко- 
пии. Возможно побитовое сравнение для выбора теку- 
щих файлов для копирования. Также возможна кор- 
рекция ошибок при извлечении данных с поврежден- 
ных дискет, жестких дисков и магнитных лент. 

Восстановление утраченных данных 

Эта традиционная для РС Тооіз функция предна- 
значена для восстановления данных на диске, утра- 
ченных вами почти по любым возможным 
“сценариям**: после уничтожения или повреждения 
файлов, из-за нарушений в работе жестких дисков и 
даже из-за нечаянного форматирования дисков. Че- 
тыре различные утилиты выполняют эту важную фун- 
кцию. 

Утилита ПізкГіх консультирует пользователя о со- 
стоянии и использовании дисков, объясняет, как сле- 
дует понимать сообщения 008 об ошибках, произво- 
дит автоматическую диагностику гибких и жестких 
дисков, а также их последующее “лечение**. Причем 
команда “І7пёо“ все изменения позволяет опять при- 
вести в прежнее состояние. Могут подвергаться 
“лечению** любые диски с нарушенной таблицей раз- 
биения ( РагШіоп ) диска, с поврежденной загрузоч- 
ным ( Вооі ) сектором, с потерянными кластерами, с 
поврежденной таблицей расположения файлов (РАТ), 
разрушенным корневым каталогом и подкаталогами 
или с файлами, которые “переплелись** друг с другом. 

Утилита РіІеРіх позволяет восстанавливать повреж- 
денные файлы форматов сІВАЗЕ, Ьоіиз 1-2-3 (в том 
числе и версии 3.x) и 8угаГопу. 

Превосходная утилита Шбеіеіе восстанавливает 
уничтоженные файлы как в отдельном компьютере, 
так и в локальной сети. Эта утилита также работает 
под Б08 и АѴіпбочѵз. При использовании для уничто- 
жения файлов утилиты 8еп1гу, не позволяющей 
использовать для перезаписи освободившееся про- 
странство на диске, практически всегда возможно 
полное восстановление уничтоженных данных, даже в 
сети. 

Уничтоженные файлы сортируются по дате, вре- 
мени и состоянию. Даже если уничтожен подкаталог, 
возможно восстановление файлов, баз данных и элек- 
тронных таблиц. Кроме того, возможно детальное вос- 
становление сильно поврежденных файлов вручную. С 
помощью этой утилиты возможно восстановление 
файлов, разорванных на отдельные фрагменты, на- 


пример, после неудачной “оптимизации** диска, после 
переписывания или перемещения имен каталогов, ча- 
стично — после перезаписи файлов или после случай- 
ного форматирования диска. 

Утилита ІІпГогшаі “ремонтирует** жесткий диск: 
вновь воссоздает утраченную таблицу РАТ по ее 
“отраженному** образу в специальном защищенном 
файле Міггог, который всегда находясь в корневом ка- 
талоге на диске, сохраняет и регулярно обновляет 
информацию, необходимую для восстановления таб- 
лицы расположения файлов. При этом после 
“деформатирования** диска гарантируется 100%-ное 
восстановление утраченных данных, если диск был 
отформатирован специальной утилитой РС Тооіз 7.0. 

Защита данных и дисков 

С помощью нескольких утилит ваши ценные дан- 
ные могут быть надежно защищены от потерь из-за 
случайного форматирования диска, заражения виру- 
сами, нарушений в работе носителей или потери па- 
мяти СМ08. 

В РС Тооіз 7.0 имеется весьма полезная утилита 
для безопасного освежения адресов дисковых секторов, 
которые записываются только однажды при формати- 
ровании и обычно со временем стареют и размагничи- 
ваются. Рано или поздно это приводит к потере дан- 
ных или даже к полному “крушению** жесткого диска, 
когда вдруг ваш компьютер начинает выдавать непри- 
ятные сообщения типа “8ес1ог поі 1оип<1“ или “8еек 
еггог“. Эта утилита РС Тооіз 7.0 тщательно сканирует 
всю поверхность диска, производя испытания на чте- 
ние/запись по 80 параметрам, чтобы обнаружить и 
отбраковать вновь возникающие ненадежные секторы. 
Затем корректируется фрагментация файлов на диске 
и настраивается фактор чередования сегментов для 
оптимизации скорости работы жесткого диска. 

Специальная резидентная программа, занимающая 
20 Кбайт в ОЗУ, способна, как утверждает фирма 
Сепігаі Роіп ЗоМѵаге, распознать свыше 600 вирусов в 
любом файле, каталоге, в памяти или в загрузочном 
секторе. При диагностировании вируса после его по- 
ступления в компьютер по сети или с дискетами, она 
немедленно отключает жесткий диск, дает сообщения 
новых версий вирусов. Служба поддержки Сепігаі 
Роіпі Зоііѵѵаге обязуется регулярно снабжать зареги- 
стрированных пользователей обновленными версиями 
этой утилиты. 

Таблица расположения файлов на диске (РАТ), за- 
грузочный (Воо!) сектор и корневой каталог любого 
диска могут сохраняться в специальном защищенном 
файле, создаваемом утилитой Міггог, на тот случай, 
если понадобится быстро и надежно восстановить диск 
после неожиданного аварийного отключения питания 
или после случайного форматирования диска. 

Специальная загрузочная дискета, создаваемая РС 
Тооіз 7.0, позволяет перезагрузить компьютер после 
любой неисправности, так как на ней имеются все не- 
обходимые для восстановления файлы, включая загру- 


4 Зак. 2503 
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зочный сектор, таблицу разбиения диска и образ 
СМ05-памяти. 

Сервисная система Безкіор 

С помощью системы Оезкіор можно легко и удобно 
организовать групповое использование персонального 
компьютера, вести всевозможные записи в записной 
книжке и в простой базе данных, пользоваться кален- 
дарем и калькулятором, составлять списки “что сде- 
лать“, а также получать в установленный срок напо- 
минания, скажем, о назначенной встрече или о сове- 
щании с коллегами в локальной сети. Эта же система 
позволяет производить регулярное резервное копи- 
рование данных, автоматически отправлять в удобное 
время факсимильные сообщения и электронную 
почту. 

База данных системы Оезкіор совместима с фай- 
лами формата «ІВА5Е, что позволяет легко пользо- 
ваться имеющимися файлами, создавать и редактиро- 
вать новые файлы, составлять списки и отчеты, 
“сливать" тексты стандартных писем с адресами и 
осуществлять автоматический набор телефонных но- 
меров через модем. 

В простом текстовом процессоре, встроенном в 
Оезкіор, можно легко создавать любые по объему до- 
кументы. В нем имеется функция Маіі-тег^е, позво- 
ляющая “сливать" тексты писем с адресами из базы 
данных. На экран могут выводиться одновременно до 
15 “листков" из электронной записной книжки. В тек- 
стовом процессоре имеются практически все важней- 
шие функции специализированных программ такого 
типа: автоматическая проверка правописания английс- 
кого языка, поиск и замена фрагментов текста, пере- 
мещение фрагментов текста, форматирование стра- 
ницы перед печатью. 

В РС Тооіз 7.0 имеется сразу 4 встроенных кальку- 
лятора — обычный алгебраический и специальные для 
научных и финансовых расчетов, а также для про- 
граммистов. Автоматически через модем могут наби- 
раться номера любых телефонов, либо вводимых в ко- 
мандной строке, либо сохраняемых в системе Безкіор 
или в любой другой прикладной программе. Трудно 
кратко перечислить все возможности, представляемые 
в системе Оезкіор. Вот для примера еще несколько. 

С помощью утилиты СІірЬоагсІ в системе Оезкіор 
можно “вырезать" любые данные, отображаемые на 
экране, и вставлять их в различные приложения. Ути- 
лита Магсо ебііог позволяет системе запоминать лю- 
бые длинные комбинации клавиш, которыми вам при- 
ходится часто пользоваться, а затем воспроизводить 
всю эту макрокоманду после нажатия лишь одной 
условной клавиши. А чрезвычайно полезная утилита 
Оиіііпег предназначена для составления планов и рас- 
писаний, оглавлений и списков важных мероприятий, 
встреч, покупок и тому подобных дел и событий, из 
которых состоит жизнь любого занятого человека, для 
разработки и обдумывания структуры различных до- 
кументов, докладов, речей, романов. 


Управление дисками и файлами 

Утилиты РіІеРіпб и Ѵіе\ѵ позволяют весьма удобно 
и оперативно находить по любым признакам (а в тек- 
стовых файлах даже по образцу фрагмента текста!) и 
просматривать файлы данных различного формата из 
более чем 35 распространенных прикладных 
программ: из практически всех наиболее популярных 
текстовых процессоров, электронных таблиц, систем 
управления базами данных, а также просматривать 
графические файлы формата РСХ из программы РС 
РаіпіЬгизН и из архивов форматов АКС, Ь2Н, РАК, 
РК2ІР и 200. 

Оболочка 005, предлагаемая в РС Тооіз 7.0, на 
наш взгляд, более удобна и гораздо богаче возможно- 
стями, чем, скажем, известная оболочка Ыогіоп Сош- 
тапбег или 005 5Ье11 версии 4.01. Впрочем, по- 
скольку “на вкус и цвет товарищей нет", выбор под- 
ходящей оболочки остается делом весьма индивиду- 
альным: последнее слово в окончательном выборе 
всегда должно оставаться за пользователем. Доста- 
точно назвать несколько отличительных особенностей 
имеющейся оболочки 005: просмотр содержимого 
двух файлов одновременно, копирование файлов на 
несколько дисков, возможность резидентного располо- 
жения в памяти (оболочка занимает при этом всего 10 
Кбайт), переназначение функциональных клавиш по 
вашему вкусу и многое другое. 

Помимо перечисленных возможностей, оболочка РС 
Тооіз 7.0 позволяет защищать имеющиеся прикладные 
программы от нежелательного доступа посторонних 
лиц секретным паролем. Замечательно, на наш взгляд, 
выглядит и графическое представление объема катало- 
гов (точнее, того, сколько места они занимают на 
диске) при просмотре дерева каталогов на экране. 

Системная и сетевая информация 

РС Тооіз 7.0 производит всестороннее тестирование 
системы утилитой 51 и сообщает пользователю более 
чем о 160 параметрах, исчерпывающе характеризу- 
ющих используемую компьютерную систему и под- 
ключенную коммуникационную сеть. 

Помимо многочисленных полезных данных о типе 
используемого процессора и его производительности, о 
версии операционной системы, о прерываниях, о типе 
видеоадаптера, о различных текстовых параметрах 
скорости чтения/записи дисководов и другой 
внутренней статистике, на экране графически 
отображается информация о распределении памяти. 
Детально сообщается об используемых физических и 
логических дисках (включая сетевые) и о виртуальных 
КАМ- дисках. 

Утилита 51 подробно сообщает также о всех 
сетевых параметрах, о версии и изготовителе сетевого 
программного обеспечения, дает детальный и 
обобщенный отчет о каждом сетевом сервере, 
составляет списки серверов, список пользователей по 
каждому серверу, а также выводит всевозможную 
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информацию о группах пользователей и о простран- 
стве сервера для каждого клиента. 

Графически в виде гистограмм отображаются ре- 
зультаты теста ВепсНшагк — сравнительная скорость 
работы процессора и дисков, обобщенная производи- 
тельность системы, а также график производительнос- 
ти сети по времени чтения/записи на сервер. Кроме 
того, не выходя из РС Тооіз, можно просматривать 
файлы АІІТОЕХЕС.ВАТ и ССЖРІС.ВѴЗ, а также по- 
лучить другие данные о конфигурации системы. 

Использование компьютера на расстоянии 

Система связи Согатиіе пакета РС Тооіз 7.0 позво- 
ляет с помощью, например, домашнего персонального 
компьютера или переносного Іаріор-компьютера за- 
пускать прикладные программы, работающие под 
управлением ООЗ и >Ѵіп<іо\ѵ5 в компьютерах или в ло- 
кальной сети где-то на удалении, скажем, на вашем 
предприятии или в учреждении. Передача информа- 
ции по кабелю, по телефонной линии через модем 
или в локальной сети ускоряется вдвое, благодаря 
компрессии данных. Можно распечатывать файлы, 
управлять приложениями ѴЛпбоѵѵз и пользоваться 
мышью либо на собственном, либо на удаленном 
компьютере. Система Соштиіе функционально 
совместима с сетями типа Моѵеіі (версия 2.15 и выше) 
и позволяет получать и передавать электронную почту 
и получить доступ к любому персональному 
компьютеру сети через модем. 

Ваш компьютер может быть защищен от нежела- 
тельного доступа секретным паролем, автоматически 
отзываясь и требуя подтверждения права доступа. 
Причем защита от несанкционированного доступа мо- 
жет быть многоуровневой, а вся запрашиваемая 
информация регистрируется. Эта система Соштиіе 
имеет множество других дополнительных полезных 
сервисных удобств, предназначенных для существен- 
ного облегчения работы в локальной сети. 

Оптимизация технических 
характеристик системы 

Помимо уже упоминавшихся утилит, позволяющих 
диагностировать и максимально оптимизировать ско- 
рость работы жесткого диска, благодаря дефрагмента- 
ции и реорганизации расположения файлов на диске, 
а также благодаря оптимальной настройке фактора 
чередования в последовательности расположения сек- 
торов в каждом из цилиндров жесткого диска, в РС 
Тооіз 7.0 имеется дополнительная возможность уско- 
рить операции чтения/записи жесткого диска, за счет 
сохранения наиболее часто используемых данных в 
кэш-памяти. 

Утилита Оізк СасЬе также работает под )Ѵіп<1о\ѵз и 
позволяет использовать расширенную и дополнитель- 
ную (ЕМ5) память компьютера. В кэш-памяти однов- 
ременно могут сохраняться данные, относящиеся сразу 
к четырем жестким дискам. 


Телекоммуникация 

С помощью встроенных утилит коммуникации, вхо- 
дящих в РС Тооіз 7.0, ваш компьютер может быть 
присоединен к другим компьютерам как внутри ва- 
шего предприятия или учреждения, так и к любому 
персональному компьютеру в любом конце света, 
используя связь по телефонным линиям через модем, 
факс-плату или подключение к службам электрон- 
ной почты типа МСІ шаіі, СошриЗегѵе или Еазу- 
Ііпк. 

Процесс передачи и получения электронной почты 
максимально автоматизирован. Поддерживается эму- 
ляция терминалов АЫЗІ, ѴТ100 и ѴТ52. Через модем 
можно передавать файлы, используя протоколы 
ХМСЮЕМ или А5ІІ. Факсимильные сообщения можно 
посылать и получать как на обычный аппарат факс, 
так и на другой персональный компьютер, снабжен- 
ный встроенной факс-платой в разъеме расширения. 

Безопасность хранения данных 

Учитывая ценность информации, которая может 
храниться в персональных компьютерах, богатый вы- 
бор разнообразных мер обеспечения безопасности и 
секретности, предлагаемых пакетом РС Тооіз 7.0, по- 
жалуй, никак нельзя считать излишним. 

Любая конфиденциальная информация, содержаща- 
яся в ваших файлах и каталогах, находящихся на дис- 
ках и передаваемых в сетях, может включать автома- 
тическую шифровку по вашему собственному секрет- 
ному паролю. 

Кроме того, предусмотрена защита указанных поль- 
зователем файлов, каталогов и системных областей 
или всего диска от случайной перезаписи. Экран мо- 
нитора, содержащий конфиденциальную информацию, 
может не только очищаться (и тем самым продлевать 
срок службы монитора), но и имеет встроенную за- 
щиту по паролю, чтобы в ваше отсутствие ограничить 
нежелательный доступ к компьютеру для. посторонних 
лиц. И, наконец, имеется традиционная для РС Тооіз 
утилита )Ѵіре, позволяющая бесследно уничтожать не- 
нужные данные в файлах или на всем диске. 

Минимальные требования к системе 

Пакет РС Тооіз 7.0 предназначен для работы на 
персональных компьютерах типа 1ВМ РС, ХТ, АТ, 
Р5/2 или на 100% -совместимых машинах, имеющих 
640 Кбайт ОЗУ и Б08 3.0 или выше. Применение 
003 5.0 рекомендуется. Приложения АѴішкнѵз могут 
выполняться, если имеется МісгозоН ѴЯпбоѵѵз 3.0 или 
выше и 2 Мбайт ОЗУ. В любом случае необходим 
жесткий диск. Поддерживаются драйверы мыши Мі- 
сгозоН Моизе версии 6.14 или выше, а также драйверы 
мыши Ьо^ЦесЬ/Оехха версии 3.4 х или выше либо 
100% -совместимые. Предполагается использование 
модема типа Науез, поддерживается КеІ\Ѵаге 2.15 или 
выше и ЫеіѴ(аІе 386. 
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РС ТООІЗ 7.0 — ИНТЕГРИРОВАННЫЙ ПРОФЕССИОНАЛЬНЫЙ ИНСТРУМЕНТАРИЙ 


Хотя бета-версии программ обычно не вполне со- 
впадают с готовым продуктом (в конце концов, для 
того они и создаются, чтобы искать в них возможные 
ошибки и недостатки), без риска ошибиться можно 
уже сегодня предположить, что новому пакету РС 
Тооіз 7.0 уготована не менее успешная судьба, чем его 
предшественнику. Преемственность испытанных и уже 
нашедших широкое признание инструментов в РС 
Тооіз 7.0 не только тщательно сохранена, но и 
Существенно обогащена новыми мощными и 
полезными возможностями, хотя в этой статье не- 
возможно было упомянуть и прокомментировать каж- 
дую из них. Но даже некоторые из перечисленных 
возможностей РС Тооіз 7.0 могут сегодня вызвать за- 
висть и огорчения у некоторых читателей или пока- 
заться явно излишними из-за скудных технических 
возможностей отечественного парка компьютеров и се- 
тей коммуникации. Кто-то может даже сказать, что 
“они там с жиру бесятся" или пробурчать что-то об 
“элитарности" утилит для АѴішіо>ѵз. 

Не стоит, однако, забывать, что создается этот па- 
кет отнюдь не по нашей мерке, а прежде всего для за- 
падного рынка. Во-вторых, прогресс все-таки происхо- 
дит и у нас, хотя, быть- может, и не столь стреми- 
тельно, как нам того хотелось бы, а каждый шаг в 
улучшении проклятого “железа" -заставляет раскоше- 
ливаться. Однако рано или поздно большинство этих 
возможностей РС Тооіз 7.0 станут полезными и акту- 
альными для многих. Ну и, наконец, в-третьих, про- 
цесс инсталляции позволяет выбирать из обширного 


интегрального инструментария РС Тооіз 7.0 только те 
инструменты, которые вам нужны или могут быть по- 
лезны именно сегодня, и тем самым позволяет сэконо- 
мить используемое дисковое пространство и свободную 
память. Пользователь может даже “дезинтегрировать" 
эту систему и выбрать из нее лишь несколько самых 
необходимых утилит, которыми можно пользоваться 
даже на самом скромном персональном компьютере. 

Девиз Сепігаі Роіпі БоМѵаге гласит; “Сделаем так, 
чтобы работа на компьютере стала безопаснее, проще, 
быстрее". Несомненно, представленный сегодня интег- 
рированный пакет утилит РС Тооіз 7.0 — это верный 
очередной шаг в указанном стратегическом направле- 
нии. Ну, а каков окажется окончательный вариант 
этой программы, надеюсь, все мы скоро сможем 
узнать. 

Для желающих связаться с мюнхенским филиалом 
Сепігаі Роіпі БоЯѵаге, который отвечает за маркетинг 
и поддержку продуктов этой фирмы в ФРГ, Австрии, 
Швейцарии и в странах Восточной Европы, сообщаем 
контактные реквизиты: 

Сепігаі Роіпі ЗоГЬѵаге ОеиізсЫапб СтЬН 
Ьеороібзіг. 28 а/ІІ 
8000 МипсЬеп 40 
ВІШ 

Телефон: (089) 33 67 17 
Факс: (089) 33 57 31 

А.В. Летроченков 
Телефон: (08100) 5 58 05 


сіетоз/* предлагает: Система Автоматизации “ЛабСервис” 

Программно-технический комплекс “ЛабСервис” - это набор стандартных плат для ІВМ РС АТ/ХТ и пакет 
программ для М8 БОЗ. 

Набор плат “ЛабСервис” для ІВМ-совместимых компьютеров: 

Платы АЦП-ЦАП. Платы релейных коммутаторов и цифровых каналов. Платы цифровых каналов (до 24 вх/вых.). Платы интерфейса 
канала общего пользования. Платы ЦАП. Платы аналоговых усилителей. Блок АЦП: 20 разр., связь по К8-232 (изготавливается на заказ) . 
Контроллер крейта КАМАК для ІВМ РС. 

“ЛабСервис” обеспечивает: 

• многоканальный ввод/вывод аналоговых и цифровых сигналов, нормирование аналоговых сигналов, высокую скорость процедур 
сбора данных (до 1 0 кГц) ; 

• разнообразные алгоритмы сбора данных и управление процессами в реальном масштабе времени; 

• оперативное отображение на экране собираемых данных и управляющих воздействий; 

• сохранение полученных данных в форматах различных пакетов для их последующей обработки (МаіЬЬаЬ, сіВа$е, Ргашеѵѵогк и др.) 

• реализацию сложных сценариев процесса, отражающих взаимодействие и синхронизацию процедур сбора данных и управления; 

• ведение архива сценариев и результатов. 

Пакет удобен в использовании и не требует знания программирования - с помощью 
систем меню можно быстро описать требуемые процессы. 

ДЕМОС/*: 1 1 3035 Москва, Овчинниковская наб. дом 6/ 1 , 
телефон: 231-21-29, 231-63-95; Рах: (095) 233.5016; Е-таі1: іпГо@Ьд.бето8.8и 
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С момента нажатия клавиши на 
клавиатуре до отображения прикладной 
программой символа на экране 
совершается целая последовательность 
событий. Эта статья начинается с 
обзора прерываний, обслуживающих 
события, связанные с клавиатурой. 
Затем рассматриваются программные и 
аппаратные средства, относящиеся к 
клавиатуре и ее прерываниям; 
непонятная техническая терминология 
попутно поясняется. Далее 
предлагаются примеры программ, 
демонстрирующих внутреннюю работу 
клавиатуры. И, наконец, представлены 
некоторые утилиты, улучшающие 
функциональные возможности 
клавиатуры. Статья перепечатывается 
из журнала Місгозор. Зузіет Іоитаі, ѵ.5, 
N 0 . 1 , 1990 с любезного разрешения 
фирмы Місгоюр. 


Клавиатура: от Л до 2 


Подробное исследование 
работы клавиатуры ПК 
и обслуживающих ее прерываний 


При работе с любой программой стоит вам только 
нажать на клавишу, как на экране мгновенно появля- 
ется символ. Это позволяет предположить, что между 
монитором и клавиатурой существует непосредствен- 
ная связь. В действительности в процесс, сопровожда- 
ющий нажатие на клавишу, включены мириады со- 
ставных частей. 

Первым шагом на пути к пониманию работы клави- 
атуры становится знакомство с системой 
обслуживания прерываний ПК. Под прерыванием 
понимается временное прекращение центральным 
процессорным устройством (СРП — ЦПУ) текущей 
работы для выполнения некоторых посторонних 
действий, по завершении которых процессор 
возвращается в прежнее состояние и продолжает 
прерванную работу. Каждое прерывание имеет свой 


номер, по которому ЦПУ находит подпрограмму для 
его обработки. Семейство процессоров 80x86 
обеспечивает работу с двумя типами прерываний — 
программными и аппаратными. Аппаратное 
прерывание возникает тогда, когда какое-либо 
устройство нуждается в экстренном обслуживании и, 
как правило, такое прерывание — большая не- 
ожиданность для ЦПУ. 

В отличие от аппаратных, программные прерывания 
инициируются изнутри основной программы при по- 
мощи специальных команд процессора. Программное 
прерывание можно представить так, как будто про- 
грамма прерывает сама себя для выполнения подпро- 
граммы, не являющейся частью ее кода. Обращение к 
программному прерыванию похоже на вызов функции, 
за тем исключением, что нет необходимости написа- 
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ния самой функции. К одной из основных задач опе- 
рационной системы ФОБ или 08/2) относится обес- 
печение пользователя набором стандартных подпрог- 
рамм обработки прерываний с тем, чтобы отпала не- 
обходимость многократного переписывания наиболее 
общих (и, надо отметить, наиболее неприятных) на- 
боров команд для всех выполняемых прикладных про- 
грамм. 

При нажатии на клавишу электронные схемы кла- 
виатуры генерируют аппаратное прерывание, инфор- 
мирующее ЦПУ о том, что произошло событие, кото- 
рое необходимо немедленно обработать. Экстренность 
обработки обусловлена тем, что клавиатура способна 
запоминать только до 4 нажатий. Если эти нажатия 
не будут переданы процессору, то они потеряются. 
Для предотвращения этого ЦПУ запоминает текущее 
состояние задачи (например, пересчет электронной 
таблицы) и выполняет специальную программу обра- 
ботки сигналов клавиатуры. Эта программа называется 
ШТ 09Н или “обработчик аппаратного прерывания от 
клавиатуры". Так как обработка данных с клавиатуры 
относится к наиболее важным функциям системы, 
программа обработки ШТ 09Н встроена в ПЗУ и яв- 
ляется частью ВІ08. 

Прерывание І1ЧТ 09Н 

Основная функция программы ВІ08 ШТ 09Н — 
получение информации о нажатии на клавишу через 
порт ввода/вывода А микросхемы 8255-А, обработка 
этой информации и сохранение ее в буфере клави- 
атуры. Буфер клавиатуры — это небольшой участок 
памяти в зарезервированной области ОЗУ, называемой 
областью данных ВІ08. Единственная информация, 
которую программа обслуживания прерываний полу- 
чает от клавиатуры — это число, называемое скан-ко- 
дом и представляющее собой физический номер нажа- 
той или отпущенной клавиши. Большинство приклад- 
ных программ ожидают поступления от клавиатуры 
кода символа (А5СІІ-кода), поэтому каждое нажатие 
на клавишу приходится специальным образом обраба- 
тывать. Например, при нажатии на клавишу “А“ кла- 
виатурой посылается число (скан-код) 1ЕН. Про- 
грамма ШТ 09Н определяет по таблице, что это кла- 
виша А. Попутно ШТ 09Н проверяет состояние не- 
символьных клавиш, таких как СарзЬоск и левый или 
правый 8НІН с тем, чтобы определить, прописная это 
буква или строчная. Затем скан-код и его А5СІІ-ин- 
терпретация запоминаются в буфере клавиатуры и 
программа ШТ 09Н завершается. ЦПУ — или, вер- 
нее, счетчик команд — возвращается на то самое ме- 
сто, в котором его работа была прервана. При этом 
система восстанавливается таким образом, что пре- 
рванная программа и “не подозревает", что была на 
некоторое время “заморожена". 

Если работа ШТ 09Н происходит “совершенно не- 
заметно", то как же осуществляется передача при- 
кладной программе информации о введенных симво- 
лах? Для этого в операционной системе имеется не- 


сколько подпрограмм, объединенных под эгидой обра- 
ботчика программного прерывания ШТ 16Н. 

Прерывание ШТ 16Н 

Если единственная обязанность аппаратного преры- 
вания ШТ 09Н — это прием данных с клавиатуры, их 
интерпретация и занесение в буфер, то программное 
прерывание ШТ 16Н обладает большей гибкостью, 
предоставляя целых 3 подфункции (пронумерованные 
от 0 до 2). Прикладная программа задает необходи- 
мую функцию путем передачи обработчику ШТ 16Н 
номера этой функции в регистре АН перед выполне- 
нием прерывания. 

Первая функция (с номером 0 или ООН) передает 
прикладной программе информацию о нажатой кла- 
више (ее скан- и А5СІІ-коды) из буфера клавиатуры. 
При использовании этой функции надо учитывать 
одну ее особенность. Дело в том, что буфер клави- 
атуры большую часть времени пуст, а прерывание 
ШТ 16Н ООН (т.е. прерывание ШТ 16Н, функция 
ООН) обязано вернуть информацию о нажатой кла- 
више. Поэтому функция ООН заставляет ЦПУ выпол- 
нять цикл ожидания до тех пор, пока в буфере не по- 
явится какой-либо код — т.е. пока не будет нажата 
какая-нибудь клавиша. 

Для того, чтобы понять, каким образом во время 
пребывания процессора в цикле ожидания в буфер по- 
ступает информация, обратимся к прерыванию 
ШТ 09Н. Это аппаратное прерывание вырабатывается 
при любом нажатии на клавишу и, прерывая просмотр 
функцией ШТ 16Н ООН буфера клавиатуры, заносит в 
него данные. После окончания работы прерывания 
ШТ 09Н, функция ШТ 16Н ООН внезапно обнаружи- 
вает поступившие с клавиатуры данные и передает их 
прикладной программе. 

Функция 01 Н прерывания ШТ 16Н в некоторых 
случаях более эффективна. Эта функция позволяет 
программе определить, есть в буфере данные или нет 
и затем немедленно возвращает управление приклад- 
ной программе. Все, что остается программе — это 
периодически обращаться к функции ШТ 16Н 01Н и 
проверять заполненность буфера. Если будет получен 
ответ “да", то программа сможет немедленно прочи- 
тать символ с помощью функции ШТ 16Н ООН. 

Последняя функция прерывания ШТ 16Н имеет 
номер 2 (02Н) и возвращает текущую информацию о 
клавишах СарзЬоск, Іпзегі, ЫитЬоск, ЗсгоПЬоск, АН, 
Сігі, левый и правый ЗЫН. Мы вернемся к этой фун- 
кции несколько позднее. 

Таким образом, главное отличие между ШТ 09Н и 
ШТ 16Н состоит в том, что ШТ 09Н является аппа- 
ратным прерыванием, выполняемым В108, и исполь- 
зуется исключительно клавиатурой для сохранения 
данных о нажатых клавишах. ШТ 16Н — это про- 
граммное прерывание, выполняемое ПЗУ ВЮЗ и 
используемое прикладными программами по мере не- 
обходимости для получения данных о нажатых клави- 
шах. 
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Подробнее о прерываниях 

Так как концепция прерываний является ключевой 
в понимании функционирования клавиатуры (как 
впрочем и любых других устройств), рассмотрим ра- 
боту прерываний поподробнее. Как для программных, 
так и для аппаратных прерываний семейство процес- 
соров 80x86 выполняет одну и ту же последователь- 
ность операций. В обоих случаях управление временно 
передается программе, называемой обработчиком пре- 
рывания. При возникновении аппаратного прерывания 
переход на его обработчик вызывается воздействием 
сигнала, поступающего на специальный вывод процес- 
сора. Программные же прерывания инициируются са- 
мим процессором при выполнении инструкции ШТ 
(ШТеггирІ — прерывание). У команды ШТ имеется 
обратная команда — ІКЕТ (Іпіеггирі КЕТигп — воз- 
врат из прерывания), используемая обработчиком пре- 
рывания для возврата управления прерванной про- 
грамме. Рассмотрим сначала, что делает ЦПУ при вы- 
полнении команды ШТ. 

При возникновении прерывания, независимо от 
того, инициировано оно извне — аппаратно, или 
изнутри — программой, ЦПУ прежде всего сохраняет 
текущее состояние регистра флагов в стеке. После 
этого очищаются флаг прерываний (ІР) и флаг трас- 
сировки (ТР). Очистка флага ІР (ІпІеггирІ-епаЫе 
Ріа^) делает то же, что и инструкция СЫ (Сіеаг Іпіег- 
гирІ-епаЫе Ріав — очистка ІР, запрет прерываний) — 
запрещает прерывания (все, кроме немаскируемых 
прерываний, напр., ШТ 02Н), обеспечивая непрерыв- 
ную работу ЦПУ в течение всего времени выполнения 
процедурой ШТ критичного задания. Обработчик пре- 
рываний должен разрешить прерывания сразу, как 
только это станет возможно, используя команду 8ТІ 
(8еІ ІпІеггирІ-епаЫе Пае — установка ІР, разрешение 
прерываний). Тем самым будет разрешено выполнение 
других критичных по времени прерываний. Примером 
критичного по времени прерывания может служить 
ввод символа через порт связи и его буферизация. 
Однако инструкция 5ТІ может быть опущена, если 
код обработчика очень короткий. Очистка флага ТР 
(Тгар Ріаё) необходима для обеспечения правильной 
работы программ-трассировщиков. Если флаг 
трассировки не сбросить, то и сам обработчик будет 
прерываться после каждой выполненной инструкции, 
что приведет к банальному зависанию. 

Далее ЦПУ сохраняет в стеке текущее значение ре- 
гистра сегмента кода (С8). Затем в СЗ заносится зна- 
чение сегмента адреса обработчика прерывания, 
взятое из таблицы векторов прерываний. Таблица 
векторов прерываний находится в нижней части 
памяти — в самом ее начале (стартовый адрес 
0000:0000). Индексация (выборка нужного адреса) в 
таблице производится путем умножения номера 
прерывания на 4 и добавления 2 (для сегментного 
адреса). Двойка добавляется из-за обратного порядка 
записи адресов, принятого в процессорах Іпіеі — 
вначале размещается смещение, а затем сегмент. 


Такое “перевертывание" является следствием 
принципа “более значимая информация хранится в 
более старших адресах". (На самом деле никакого 
перевертывания здесь нет. Просто более старшие 
информационные разряды чисел записывается в более 
старших байтах памяти. Так адрес РРРС:08А5 
реально в байтах памяти запишется, как А5 08 РС РР, 
аналогично тому, как слово 25В7 записывается в 
памяти в виде В7 25.) 

После этого в стеке сохраняется скорректированное 
значение указателя инструкций (или счетчика ко- 
манд — ІР — Іпзігисііоп Роіпіег), указывающее на 
следующую за прерванной выполняемую команду. Да- 
лее в ІР заносится смещение обработчика прерываний 
из таблицы векторов прерываний. Индексация смеще- 
ния в таблице производится путем умножения номера 
прерывания на 4. 

В результате этого процесса управление передается 
процедуре, указываемой новой парой адресов С5.ІР, 
т.е. программе обработки прерывания. (На самом деле 
производится просто Іаг-вызов программы-обработчика 
по адресу из таблицы векторов прерываний — 
САН РАК (ШТ*4), где ШТ — номер прерывания.) 
Как указывалось, одно из первых действий, которое 
выполняет обработчик, это разрешение прерываний 
командой 8ТІ. Затем все регистры, которые обработ- 
чик может модифицировать, сохраняются в стеке. Да- 
лее выполняется непосредственно обработка прерыва- 
ния. По ее завершении значения регистров восстана- 
вливаются. Если обработчик вызывается аппаратным 
прерыванием, он информирует Программируемый 
Контроллер Прерываний (РІС) об окончании обслу- 
живания прерывания посылкой команды (ЕОІ). 

И, наконец, обработчик выполняет инструкцию 
ІКЕТ. ІКЕТ возвращает управление прерванному про- 
цессу, выполняя действия, противоположные тем, ко- 
торые выполняются инструкцией ШТ. Первым из 
стека заполняется регистр ІР. Следующее слово вы- 
талкивается в регистр сегмента кода — это адрес сег- 
мента, в котором расположена следующая выполня- 
емая инструкция. Последнее слово выталкивается в 
регистр флагов. 

Этот процесс возвращает управление программе 
точно в то место, где она была прервана. Так как со- 
стояние машины (особенно ее регистров и флагов) 
восстанавливается в исходное, прерываемая программа 
“не чувствует** приостановки в работе и продолжает 
выполнение без каких-либо потерь. 

Методика использования таблицы векторов преры- 
ваний упрощает внесение изменений в программы 
прерываний. Все, что нужно сделать — это изменить 
адрес входной точки прерывания в таблице. Наиболее 
общие изменения в программах обслуживания преры- 
ваний происходят при изменениях в операционной 
системе. Например, в 008 3.x вектора прерываний, 
обслуживающих систему, отличны от Э08 2.x. Анало- 
гично этому, функции обработки прерываний ВІ08 у 
ІВМ РС/АТ и клонов будут различаться, но ЦПУ 
определит правильный адрес в обоих случаях. 
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Подробно о прерывании ШТ 09Н 

Напомним, что все события, связанные с клавиату- 
рой, можно разделить между двумя прерываниями — 
аппаратным ШТ 09Н, ответственным за буферизацию 
данных клавиатуры, и программным ІЫТ 16Н, выби- 
рающим данные из буфера и передающим их при- 
кладной программе. Рассмотрим прерывание ІЫТ 09Н 
подробнее (см. рис. 1). 



Рис. 1. 

Почти во всех клавиатурах содержится микросхема 
8048. 8048 является однокристальной микро-ЭВМ, со- 
стоящей из 8-разрядного микропроцессора, 64 байт 
ОЗУ и ПЗУ с содержащимися в нем скан-кодами кла- 
виш и программой. При нажатии или отпускании кла- 
виши 8048 ищет в ПЗУ скан-код, присвоенный этой 
клавише. Скан-код — это не то же самое, что А8СІІ- 
код. Например, для клавиши “А“ скан-код равен 1ЕН, 
а А8СІІ коды — 41 Н для прописной А и 61 Н для 
строчной. За преобразование скан-кода ответственно 
прерывание ІЫТ 09Н. Кроме того, 8048 различает 
этапы нажатия и отпускания клавиш. Отпускание 
клавиши отмечается установкой в 1 старшего бита 
скан-кода. 

После определения правильного скан-кода 8048 
подготавливается к пересылке 1 -байтного кода в схему 
ІД322, расположенную на системной плате ПК. 
(Наименования микросхем в каждой конкретной ма- 
шине могут быть иными, однако назначение их оди- 
наковое). Скан-код посылается до тех пор, пока про- 
цессор не получит “зеленый свет“ от схемы 874, рас- 
положенной на системной плате, подтверждающий, 
что последний переданный код был прочитан и рас- 
шифрован программой обработки прерывания 
ШТ 09Н. 

Если скан-код не может быть передан непосред- 
ственно в данный момент, он заносится в буфер ОЗУ 
клавиатуры, который я назвал бы буфером скан-кодов. 


(Не следует путать этот буфер с 16-символьным коль- 
цевым буфером в области данных системы, использу- 
емым программой ШТ 09Н для хранения символов.) 
Если буфер скан-кодов полон, то происходит перепол- 
нение и данные теряются. В таком случае 8048 
информирует об этом системный блок, посылая спе- 
циальный скан-код РРН, а прерывание ШТ 09Н ука- 
зывает пользователю на переполнение буфера клави- 
атуры звуковым сигналом. Переполнение, однако, 
происходит довольно редко. Если вам уж так хочется, 
вы можете искусственно добиться переполнения, на- 
жав несколько клавиш одновременно всей ладонью. В 
основном сигнал переполнения служит для обнаруже- 
ния таких стихийных событий, как, например, паде- 
ние книги на клавиатуру. Однако переполнение бу- 
фера клавиатуры может легко произойти в случае, 
если прикладная программа медленно отрабатывает 
нажатия на клавиши. 

Вернемся к нашему примеру. После того, как кла- 
виатура последовательно передаст скан-код буквы А 
(1ЕН), он будет принят в системном блоке схемой 
ІД328, являющейся 8-разрядным регистром сдвига (см. 
шаг 1 и последующие шаги на рис. 1). Скан-код по- 
сылается последовательным сигналом. Перед данными 
следует стартовый бит, т.е. всего посылается 9 бит. 
Приемный регистр сдвига изначально установлен в 0. 
(Он был очищен в конце предыдущей процедуры 
обработки.) При поступлении каждого 6,-гга, включая 
стартовый, освобождается место для приема следу- 
ющего путем сдвига предыдущих 8 бит регистра на 1 
разряд влево. После получения последнего бита дан- 
ных скан-код вновь преобразуется в исходный 
1 -байтный вид. В регистр сдвига поступило 9 бит, но 
он может удерживать только 8, поэтому прием по- 
следнего бита данных выталкивает из регистра старто- 
вый бит. 

Однако стартовый бит не теряется. Он используется 
для установки триггера 874 в высокое состояние (2), 
что переводит линию запроса прерываний (1К(}1) 
ШТ 09Н в высокое состояние (3). Этот триггер однов- 
ременно посылает низкий уровень процессору 8048 на 
клавиатуре, т.е. дает “красный свет“ по той же самой 
линии данных, по которой был передан скан-код. Это 
запрещает любую передачу данных клавиатурой и пе- 
реводит процессор 8048 в режим буферизации, опи- 
санный ранее. 

Аббревиатура ІЯ(2 (дословно — “запрос на преры- 
вание“ — Іпіеггирі Кеяиезі) обозначает сигнал, посы- 
лаемый устройством, требующим обслуживания. Для 
разрешения конфликтов, неизбежно возникающих при 
одновременных запросах от нескольких устройств, 
каждому устройству присваивается некоторый уровень 
приоритета. Считается, что наиболее приоритетное 
устройство имеет уровень 0 (в ІВМ РС это системный 
таймер). Для простоты номер приоритета дописыва- 
ется к “ІК(2“. Таким образом 1К(}1 означает запрос на 
прерывание от клавиатуры, имеющей уровень приори- 
тета 1. Для работы с поступающими сигналами ІК(} в 
компьютере есть Программируемый Контроллер Пре- 
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рываний (РІС) 8259, который и решает на приоритет- 
ной основе, какое из заданий обслуживать первым при 
одновременном поступлении нескольких запросов. РІС 
имеет восемь линий ІК(}. (РІС однако не ограничен 
восемью запросами. Запросы можно соединять цепью, 
используя один РІС в качестве ведущего, а остальные 
в качестве ведомых. В АТ и Р5/2 используется допол- 
нительный ведомый РІС для подключения дополни- 
тельных линий ІЖ}.) Когда РІС получает запрос, он 
устанавливает в Регистре Запросов Прерываний (ІКК) 
бит, соответствующий этому запросу. ІКК — это 
8-разрядный регистр, каждый бит которого использу- 
ется для отслеживания ІК(2, нуждающегося в обслу- 
живании. Арбитр приоритетов РІС использует этот ре- 
гистр для выбора ІК(} с наивысшим приоритетом. 

Для примера допустим, что запрос от клавиатуры 
ІК(}1 является единственным, требующим обслужива- 
ния. РІС устанавливает высокий уровень на линии 
ШТ, передающей запрос на обслуживание клавиатуры 
путем установки высокого уровня на линии Запроса 
Прерываний (ШТК) ЦПУ. ЦПУ будет поддерживать 
запрос в том случае, если прерывания были перед 
этим разрешены инструкцией 5ТІ. Обычно прерыва- 
ния разрешены, и запрещаются инструкцией СИ 
только тогда, когда программе необходимо выполнить 
критичное по времени задание, такое как изменение 
указателя стека (8Р) или чтение из порта связи. Само 
прерывание, как уже говорилось ранее, также запре- 
щает прерывания. 

Предположим, что ЦПУ примет прерывание. Тогда 
оно закончит выполнение текущей инструкции, а за- 
тем подтвердит запрос прерывания РІС посылкой 
3-битного кода Контроллеру Шины 8288 (ВС — Виз 
Соп(гоііег), как показано в (5). Контроллер Шины 
обеспечивает проход данных к месту назначения. 
3-битный код может управлять 7 типами прерываний 
ВС. Сюда входит и управление сигналом, использу- 
емым ЦПУ для приема или записи данных в память 
или порт. Таким образом происходит разделение 
между инструкциями Ш и СШТ, предназначенными 
для портов, и инструкцией МОѴ, относящейся к опе- 
рациям с памятью. 

В случае запроса на прерывание 3-битный код, по- 
сылаемый ЦПУ, является кодом сигнала подтвержде- 
ния (“зеленым светом"), посылаемым контроллером 
шины 8288 назад в РІС 8259А по однобитной линии 
подтверждения прерываний (ШТА) (6). Первый сиг- 
нал ШТА, посылаемый в 8259А, используется для 
синхронизации, подобно стартовому биту при последо- 
вательной передаче. Следующее 3-битное подтвержде- 
ние от ЦПУ к ВС посылает сигнал ШТА в 8259 для 
начала обработки запроса. Далее 8259 устанавливает 
номер вектора прерываний для ЦПУ (в случае ІОД1 
это ШТ 09Н) (7). 8259 также устанавливает регистр 
І8К так, что РІС может отслеживать, какое прерыва- 
ние в настоящий момент обслуживается. 

А как же РІС 8259 узнает, что ІК(}1 соответствует 
номер 9? Все дело в том, что РІС — программируемое 
устройство, и поэтому начальный код, выполняемый 


при загрузке компьютера, настраивает его нужным 
образом. Одним из действий, выполняемых при этом, 
будет настройка старших 5 бит байта, представля- 
ющего номер прерывания, передаваемого в ЦПУ. При 
формировании номера прерывания младшие 3 бита 
заполняются номером ІК(}. Таким образом можно ад- 
ресовать 8 векторов от ІК()0 до ІКЦ7. Единственное 
неудобство здесь состоит в том, что обработчики аппа- 
ратных прерываний, подключенных к одному РІС, 
должны иметь смежные номера. 

В ІВМ РС старшие 5 бит программируются в 
00001В, что при дополнении 3 нулями дает номер 
обработчика таймерного прерывания (ІК(}0). Таким 
образом, ІК(}1, заполняя младшие 3 бита, составляет 
полный байт равный 00001001В или 09Н. Восемь 
уровней ІК<} проецируются на прерывания от 
ШТ 08Н до ШТ 0РН. 

Очистка Программируемого 
Контроллера Прерываний 
обработчиком прерываний 

Последнее, что должна выполнять программа обра- 
ботки прерываний — это выдавать сообщение Про- 
граммируемому Контроллеру Прерываний (РІС) об 
окончании прерывания. На ассемблере это выглядит 


так: 



СІЛ 


; Запрет прерываний 

МОѴ 

АЦ20Н 

; Посылка неспецифичного конца 

ОЦТ 

20Н,АЬ 

; прерывания ЕОІ в порт 20Н 
; Восстановление всех сохраненных 
; регистров 

ІКЕТ 


; Возврат в прерванную программу 


Подробности приведены далее. Если имеются дру- 
гие запросы ІК(}, ожидающие обработки, то сразу по- 
сле получения сигнала ЕОІ, РІС посылает ЦПУ запрос 
на прерывание. Если прерывания разрешены, (любой 
хороший обработчик прерываний разрешает их, полу- 
чив управление), то ЦПУ обратится к прерываниям. 
Это означает, что обработчик прерываний, заканчива- 
ющий работу, может быть прерван сразу после ин- 
струкции ОІГГ (в нашем примере), до инструкции 
ІКЕТ. Это может показаться безопасным, однако ре- 
зультат будет катастрофическим, если такая ситуация 
повторится много раз подряд. Каждое дополнительное 
прерывание увеличивает стек на 6 байт плюс некото- 
рый объем, используемый обработчиком прерываний 
для сохранения регистров. Многократное вложение 
прерываний означает неконтролируемый рост стека, 
что может привести к перезаписи (порче) информа- 
ции в области данных или кода. В этом случае си- 
стема будет испорчена. 

Что же необходимо сделать для того, чтобы оказа- 
лось достаточно времени для выталкивания из стека 
сохраненных регистров, а также 6 байт (ІР, С8, Ріа^з) 
командой ІКЕТ. Для этого надо запрещать прерыва- 
ния командой СІЛ непосредственно перед посылкой 
ЕОІ в РІС. Разрешение прерываний будет выполнено 


5 Зак. 2503 
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командой ІКЕТ. Помимо восстановления С8 и ІР 
ІКЕТ восстанавливает содержимое регистра флагов и 
делает его таким, каким оно было до прерывания. Так 
как бит прерываний (бит, переключаемый инструкци- 
ями СІЛ и 8ТІ) в регистре флагов перед возникнове- 
нием прерывания был установлен, то восстановление 
регистра прерываний разрешает прерывания. Стек бу- 
дет очищен и далее спокойно смогут выполняться дру- 
гие прерывания. 

Для понимания того, что означает каждый бит 
байта 20Н, посылаемого в порт 20Н, необходимо за- 
метить, что схема 8259А имеет много режимов ра- 
боты, но в ПК она работает в режиме по умолчанию. 
В этом режиме 1К<3 выбираются в соответствии с фик- 
сированными приоритетами. Чем меньше номер за- 
проса ІК(}, тем выше его приоритет. ІК(}0, ШТ 08Н 
(системный таймер) имеет наивысший приоритет. За- 
прос от клавиатуры ІК(}1, ШТ 09Н имеет второй уро- 
вень приоритета. Принтер (ІК(}7, ШТ ОРН) имеет 
самый низкий приоритет. Прерывание с более низким 
приоритетом не может произойти во время обработки 
прерывания с более высоким приоритетом. Регистр 
обслуживания РІС (І8К) отслеживает, какое из пре- 
рываний обслуживается. В соответствии с этой логи- 
кой приоритетов РІС считает, что если получен сигнал 
ЕОІ от обработчика прерываний, то нужно выбрать 
следующий по приоритету запрос и начать его обслу- 
живать. Здесь заключена некоторая опасность, состо- 
ящая в том, что если послать лишний ЕОІ, то он бу- 
дет отнесен к следующему, еще не обрабатываемому 
запросу, который будет сброшен. 

Младшие 3 бита 8-битного кода ЕОІ, посылаемого в 
порт 20Н, используются РІС для определения уровня 
приоритета обработчика прерывания, посылающего 
ЕОІ. Так как РІС автоматически определяет уровень, 
то этот специфичный тип ЕОІ не нужен и не исполь- 
зуется. Поэтому младшие 3 бита устанавливаются в 0. 
Верхние 3 бита используются для индикации типа 
ЕОІ; неспецифичный для данного режима тип кодиру- 
ется как 001В. Средние два бита не используются и 
всегда устанавливаются в 0. В результате получаем 
код 00100000В или 20Н. Адрес порта 20Н — это ме- 
сто подключения схемы 8259А — чисто случайно 
имеет то же значение, что и посылаемый сигнал ЕОІ. 

При вызове прерывания ЦПУ использует номер 
прерывания как указатель в таблице векторов, содер- 
жащей адрес программы прерывания (как это было 
рассмотрено ранее). Так как таблица векторов распо- 
ложена внизу памяти, то вектор прерывания ШТ ООН 
размещается в четырех байтах, начиная с самого пер- 
вого байта памяти (0000:0000). Каждый адрес 
(вектор) занимает 4 байта — 2 для сегмента и 2 для 
смещения. Для поиска вектора, связанного с прерыва- 
нием, ЦПУ умножает номер прерывания на 4 и 
использует результат как индекс в таблице векторов. 
Выбранный адрес загружается в пару регистров С8:ІР 
ЦПУ, эффективно передавая управление программе 
обслуживания прерывания. В случае клавиатурного 
прерывания — это обработчик ШТ 09Н. 


Первое, что выполняет ШТ 09Н — получает скан- 
код. Вспомним, что скан-код находится в регистре 
сдвига Ь8322. ШТ 09Н не имеет прямого доступа к 
этой схеме и к скан-коду. Но 15322 посылает скан-код 
по 8 параллельным линиям (а не по последовательной 
линии) в порт В (адрес 60Н) другой микросхемы, на- 
зываемой Программируемым Параллельным Интер- 
фейсом (РРІ) 8255-А. 

Помимо обслуживания функций клавиатуры РРІ 
считывает значения переключателей на системной 
плате компьютера и управляет динамиком. Для пре- 
рывания ШТ 09Н РРІ служит источником скан-кодов. 
Программа ШТ 09Н считывает скан-код из порта А, 
преобразует его в символ А5СІІ и запоминает скан-код 
и символ в буфере клавиатуры. Обратите внимание на 
то, что ШТ 09Н — не единственная программа, спо- 
собная считывать из порта А. Так как считывание 
данных из этого порта, в отличие от многих других, 
не уничтожает их, то любая программа может спо- 
койно считывать скан-код. 

После того, как программа ШТ 09Н прочитает 
скан-код, можно дать “зеленый свет“ на посылку но- 
вого скан-кода. Это выполняется путем кратковремен- 
ной установки бита 7 порта В в 1 (см. 9 и рис. 2 — 
команды на ассемблере). Бит 7 соединен с линией 
очистки как 15322, так и $74. 15322 обнуляет выходы 
сдвигающего регистра, подготавливая его к приему 
следующего скан-кода. 874 сбрасывает линию ІК(}1, 
информируя процессор клавиатуры 8048 о готовности 
к приему нового скан-кода. 


Ш АЬ,20Н 

; Ввести текущее состояние порта В 

ОН АЬ,80Н 

; Установить старший бит 

7МР $ + 2 

; Переход на задержку 
; для быстрых машин 

О ЦТ 20Н.АЦ 

; Сброс клавиатуры 

АШ АЬ.ШТ 80Н 

; Сбросить старший бит 

ШР $ + 2 

; Задержка 

О ЦТ 20Н,АЬ 

; Восстановить состояние порта В 


Рис. 2. 


Как только скан-код и его А5СІІ-эквивалент будут 
сохранены в буфере, а клавиатура получит разреше- 
ние работы, программе ШТ 09Н остается только со- 
общить РІС, что она завершила работу и передает 
управление прерванной программе (10). Это выполня- 
ется посылкой сигнала ЕОІ, закодированного как 20Н, 
в порт РІС 20Н. Как отмечалось выше, совпадение 
номера порта и кода является чисто случайным. Сиг- 
нал ЕОІ сбрасывает в регистрах І5К и ІКК бит, свя- 
занный с ІК(}1, освобождая линию запроса. РІС те- 
перь может приступить к обработке аппаратных пре- 
рываний с более низким приоритетом, включая и сле- 
дующий ІВД1. 

ШТ 09Н завершает свою работу и передает управ- 
ление прерванной программе путем выполнения ко- 
манды ІКЕТ. Более подробную информацию по 8259А 
смотрите в РегірЬегіаІ НапсЗЬоок (Іпіеі, 1990). . 
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Скан-коды клавиатуры 

Как я уже указывал, ШТ 09Н интерпретирует скан- 
код, поступающий в порт А РРІ 8255А. Фактически 
программа ШТ 09Н выполняется всякий раз при ак- 
тивизации клавиатуры. Сюда относятся нажатие кла- 
виши, ее отпускание, а также удержание в нажатом 


состоянии. Клавиатура просто посылает скан-код в ПК 
программе ШТ 09Н, которая определяет, как его не- 
обходимо интерпретировать. Программа ШТ 09Н, 
расположенная в ВІ05, преобразовывает скан-коды, 
посылаемые клавиатурой, в АЗСІІ-символы, которые 
могут использовать прикладные программы. Здесь не- 
обходимо принять во внимание следующее обстоятель- 


Визуальное отображение порта скан-кодов клавиатуры. 
МісНаеІ 3 . МеНогб 


ТГШЕ РОКТ-А.А5М 
РАСЕ 60,132 

ТЕХТ ЗЕСМЕ19Т РЦВЫС СОРЕ' 
А381ШЕ СЗ: ТЕХТ 

А551ШЕ РЗГТЕХТ 

ОКО 100Н 
5ТАКТ: 1МР МАШ 


: ОАТА АКЕА 



ОВ 

СК,ЗРАСЕ,ЗРАСЕ,ЗРАСЕ,СК,ЬР 

СОРѴКІОНТ 

ОВ 

“РОКТ-А 1.0 (с) 1990 “ 

РКОСКАММЕК 

ОВ 

“МісНаеІ У Ме«ога“,СК,ЬР,ЬР,“$' 


ОВ 

СТКЬ_2 

СК 

ЕС 

Ш 

13 

ЬР 

ЕС 

Ш 

10 

СТКЬ 2 

ЕС 

Ш 

26 

ЗРАСЕ 

ЕС 

ш 

32 

ВОХ 

ЕС 

ц 

254 

ЕЗС 8САN 

ЕС 

?ц 

1 

РОКТ А 

ЕС 

ГО 

60Н 

ВЮЗ ШТ 9 

о\ 

V 

9 9 
* » * 


МЕШ ЬАВЕЬ ВѴТЕ 


ОВ “Ргезз апД геіеаае апу кеу Ю зее “ 
РВ “таке апД Ъгеак зсап соае“,СК,ЬР 

РВ “Ргезз Езс Ю ЕхіІ“,СК,ЬР,ЬР,“$“ 

; СОРЕ АКЕА 


МАШ 

САЬЬ 

МОѴ 

МОѴ 

ЮТ 

МОѴ 

ют 

МОѴ 

ют 

МОѴ 

МОѴ 

МОѴ 

МОѴ 

ШТ 


РКОС ЖАК 

сьз 

РХ.ОРРЗЕТ СОРѴКІОНТ 
АН, 9 

2Ш 

РХ.ОРРЗЕТ МЕШ 
21Н 

АХ.3509Н 

21Н 

ВЮЗ ЮТ 9[0],ВХ 
ВЮ5ПКТ~9[2] ,ЕЗ 
РХ.ОРРЗЕТ РОКТ А ЮТ 
АХ.2509Н 
21Н 


; Очистка экрана 
; Вывод Соругі^Ы и меню 


; Получить прерывание 
; клавиатуры 

; Сохранить старое 
; прерывание 
9 ; Установить новый 

; вектор 


; Находиться в цикле до появления Езс 


СЕТ КЕѴ: 

ХОК АН, АН 
ШТ 16Н 

СМР АН.ЕЗС 8САN 
Ш2 ОЕТ КЕѴ 
ЕХГГ: 

МОѴ РХ.ВІОЗ ШТ 9 [0] 
МОѴ ПЗ,ВЮ81ЫТТ»[2] 
МОѴ АХ.2509Н " 

ШТ 21Н 
САЬЬ СЬЗ 
МОѴ АХ.4С00Н 
ЮТ 21Н 


; Ожидать нажатия на клавишу 

; Если Езс, выход 
; Иначе — продолжить 

; Восстановить старый 
; вектор ШТ 9 


; Очистить экран. 

; Выход с еггог Іеѵеі = 0 


МАШ ЕЖР 


; Данная процедура вызывается каждый раз при нажатии 
; на клавишу и ей передается значение, что позволяет 
; взглянуть на скан-код и отобразить его 

РОКТ А ЮТ 9 РКОС ЖАК 
А55СМЕ ЭЗШОТНШС 


РЦЗН АХ 
РЧЗН ВХ 
РЬЗН СХ 
Ш АЬ.РОКТ А 
САІХ НЕХ ОЦТРЦТ 
ОШ ЮТ 9: “ 

РОР СХ 
РОР ВХ 
РОР АХ 

ІМР ОѴЮКО РТК ВЮЗ 
РОКТ А ЮТ 9 ЕЖР 


; Сохранить регистры 

; Получить скан-код 
; и отобразить его 

; Восстановить регистры 
НТ_9 ;переход на ВЮЗ ЮТ 9 


; Сохранить число в ВХ 
; 4 позиции/слово; 4 бита/символ 

; Старшие биты в младшие 
; Сохранить число в АЬ 
; Маскировать все, кроме четырех 
; Преобразовать в А5СІІ 
; Буква? 

; Если нет — печать 
; Иначе — подстроить 

; Печать через ВЮЗ 

; Все сделано для этих позиций? 
КОТАТЕ_НЕХ ; Если нет, взять следующую 
; Вывести два пробела 
; между скан-кодами 
; в качестве разделителей 


НЕХ ОЦТРЦТ РКОС ЖАК 
МОѴ ВХ.АХ 
МОѴ СХ.204Н 
КОТАТЕ НЕХ: 

КОБ ВЬ.СЬ 
МОѴ АЬ,ВЬ 
АЖ АЬ, 1111В 
АІШ АЬ,“0“ 

СМР АЬ,“9“ 

ІЬЕ РКЮТ НЕХ 
АЬЮ АЬ,7 “ 

РКЮТ НЕХ: 

МОѴ АН.ОЕН 
ЮТ ЮН 
ОЕС СН 
Ш2 

МОѴ СХ,2 
ОЕЫМІТ: 

МОѴ АЬ.ЗРАСЕ 
МОѴ АН.ОЕН 
ЮТ ЮН 
ШОР ОЕЬІМГГ 
КЕТ 

НЕХ ОЦТРЦТ ЕЖР 


СЬЗ РКОС ЖАК 
МОѴ АН.ОРН 
ЮТ ЮН 
СМР АЬ,7 

іг СЬЕАН 8СКЕЕN 
МОѴ АЬ,3 " 

СЬЕАК ЗСКЕЕК: 

ХОК "АН, АН 
ШТ ЮН 
МОѴ АХ.500Н 
ЮТ ЮН 
КЕТ 


; Текущий видео режим 
; Моно? 

; Если да — очистить экран 
; Иначе проверить, 

; что текстовый 

; Очистить экран 
; установкой режима 
; Убедиться, что страница 
; нулевая 


СЬЗ ЕЖР 
ТЕХТ ЕЖЗ 

ЕЖ 5ТАКТ 


ПОДПРОГРАММЫ 


Рис. 3. 
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КЛАВИАТУРА: ОТ А ДО 2 


ство. ДОТ 09Н является аппаратно-зависимой фун- 
кцией, поэтому программа для 83-клавишной клави- 
атуры отличается от версии программы для расширен- 
ной 101-клавишной клавиатуры. Очевидно, что для 
связи букв с дополнительными клавишами требуются 
дополнительные коды. 

Для лучшего понимания обратимся к программе 
РОКТ-А.А5М (рис. 3), которая в реальном времени 
отображает скан-коды, посылаемые при нажатии и 
отпускании клавиш (клавиатура посылает скан-коды в 
порт А РРІ, адрес 60Н.) Скан-коды считываются про- 
граммой РОКТ-А до того, как программа ДОТ 09Н до- 
берется до них, путем перехвата прерывания 09Н. Пе- 
рехват прерывания означает замену адреса прерыва- 
ния в таблице векторов прерываний на адрес своей 
программы обработки. Исходный адрес при этом запо- 
минается и, как только программа РОКТ-А или любая 
другая перехватившая программа завершится, управ- 
ление может быть передано первоначальному обработ- 
чику прерываний. (Хотя перехват прерываний похож 
на передачу управления Т8К-программе при нажатии 
“горячей клавиши**, РОКТ-А.АБМ не является Т8К- 
программой.) При нажатии клавиши Езс программа 
РОКТ-А восстанавливает прежнее значение в таблице 
векторов прерываний и возвращается к приглашению 
00$. * Остальные подробности программы описаны в 
комментариях в листинге программы. Вы можете 
скомпилировать представленный код. 

После запуска программы РОКТ-А при любом на- 
жатии на клавишу на экране появляется скан-код этой 
клавиши. При отпускании этой клавиши на экране 
появляется другой скан-код. Для 83-клавишной клави- 
атуры код отпускания равен коду нажатия плюс 80Н 
(10000000В), что устанавливает старший бит скан- 
кода. Это также верно и для большинства клавиш 
расширенной клавиатуры, однако для новых 
(дополнительных) клавиш — специализированных 
клавиш курсора и некоторых комбинаций клавиш — 
посылается серия скан-кодов, некоторые из которых 
имеют старший бит, установленный в 1 даже при на- 
жатии на клавишу. До появления расширенной клави- 
атуры пользователи могли легко отличить нажатие 
клавиши от отпускания проверкой старшего бита 
скан-кода. Этот способ не работает с расширенной 
клавиатурой. Программа РОКТ-А может стать удо- 
бным инструментом для определения скан-кодов, ко- 
торые должна обрабатывать программа ДОТ 09Н при 
нажатии на ту или иную клавишу. Работа программы 
РОКТ-А вполне понятна, однако значения выводимых 
скан-кодов поначалу кажутся весьма странными. Все 
становится ясно после понимания работы ДОТ 09Н. 
Для этого рассмотрим логику декодирования про- 
граммы ДОТ 09Н шаг за шагом. 

Скан-код, считываемый программой ДОТ 09Н из 
порта А, в большинстве случаев является числом, 
представляющим собой относительное положение кла- 
виши на клавиатуре. Так, скан-код 01 Н относится к 
клавише Езс, 02Н — к клавише !/1, ОЗН — @/2 и 
т.д. слева направо по верхнему ряду клавиатуры. В 


отличие от большинства компьютерных схем нумера- 
ции, отсутствует клавиша, связанная с кодом 0. 
ДОТ 09Н использует 0 как псевдо-скан-код для ото- 
бражения комбинации Сігі-Вгеак. После клавиши 
ВаскБрасе последовательная нумерация возобновляется 
с клавиши ТаЬ в ряду (}>ѴЕКТѴ. После перечисления 
клавиш пишущей машинки нумерация продолжается 
на функциональных клавишах, а далее — на допол- 
нительных. Некоторые клавиши, такие как Езс и фун- 
кциональные, на разных клавиатурах расположены в 
разных местах, поэтому для них система нумерации 
не имеет смысла. Для сохранения совместимости скан- 
коды остаются теми же. Помните, что скан-код не 
имеет ничего общего с АБСИ-эквивалентом клавиши. 


I СТІ 

Гг* 


Статус ІпмгС 1 заключай 
Статус Сар»І_оск:1 заключай 
Статус Ыитіоск 1=мло*мн 
атуе 5сгоІІІ_оск: 1 заключай 


1 


ГТ 

та 1 


Состояние АН: 1 =мажата 
Состояние С*г1: 1=иажаті 
Состояние Левый 5ЬНС 1=мажат — 1 
Состояние Правый ЗЬИС 1 =иажат 

Рис. 4, 


Для дешифровки скан-кодов ДОТ 09Н содержит 
специальную таблицу поиска. Для поиска 
соответствия в таблице используется ряд алгоритмов. 
Как только скан-код расшифрован, ДОТ 09Н 
сохраняет скан-код и АБСН-символ в буфере 
клавиатуры и возвращает управление прерванной 
программе. Однако до передачи управления ДОТ 09Н 
проверяет, не является ли скан-код кодом РРН. Как 
упоминалось выше, код РРН является кодом 
клавиатуры, указывающим на переполнение. При 
обнаружении такого кода ДОТ 09Н сообщает об этом 
сигналом динамика. В противоположном случае, 
полагая, что переполнение отсутствует, ДОТ 09Н 
просматривает таблицу перевода в. логическом 
порядке. Сначала проверяются клавиши смены 
функций: клавиши сдвига — левый и правый 5НШ, 
Сігі, АН и четыре фиксируемые клавиши — Іпзеіі, 
СарзЬоск, ЫитЬоск, БсгоІІЬоск. Если скан-код при- 
надлежит одной из четырех клавиш сдвига, это ото- 
бражается установкой соответствующего бита в 
информационном байте КО Р1АС, расположенном по 
адресу 40:17Н в области данных В108 (рис. 4). При 
обнаружении скан-кода отпускания клавиши сдвига 
соответствующий бит сбрасывается в 0. Такой метод 
позволяет программе ДОТ 09Н всегда знать, какая из 
этих клавиш нажата. 

Клавиши сдвига 


Лучший способ проиллюстрировать логику работы 
клавиш сдвига — это посмотреть, что происходит до и 
после расшифровки скан-кода программой ДОТ 09Н. 
Сначала рассмотрим, как ДОТ 09Н отработает на- 
жатие нескольких клавиш в командной строке 00$. 
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Нажмем и будем удерживать левую клавишу ЗЬіП. 
Внешне ничего не происходит. Продолжая удерживать 
левый 8ЫМ, нажмем клавишу “А“. Как и ожидалось, 
появится прописная буква А (полагаем, что клавиша' 
СарзЬоск не включена), а вслед за ней — целый ряд 
прописных А, возникающих вследствие работы фун- 
кции автоповтора клавиатуры. Отпустим левый 8НШ, 
продолжая удерживать клавишу “А“ нажатой. Про- 
писная А заменится на строчную а, а функция авто- 
повтора продолжит свою работу. 

При помощи программы РогІ-А можно увидеть, что 
в действительности происходит со скан-кодами. На- 
жмите Езс для отмены ничего не значащей команды 
ААААААаааа и запустите программу РОКТ-А. После 
этого повторите те действия, которые вы выполняли в 
командной строке П08 — начните с нажатия и удер- 
жания левой клавиши 8НІМ. Появится и будет повто- 
ряться скан-код 2АН. (Клавиатура начинает автопов- 
тор примерно через 0,5 секунды, если не изменена за- 
держка. Это справедливо для всех клавиш, включая и 
клавишу 8НІН.) Продолжая удерживать клавишу 8ЫГ1 
нажатой, нажмите клавишу “А“. Поток кодов 2АН 
заменится на 1ЕН — скан-код клавиши “А“. 
(Автоповтор прекратится, как только клавиатура 
обнаружит, что нажата другая клавиша. Если удержи- 
вать и вторую клавишу, то начнется автоповтор этой 
клавиши.) 

Далее отпустите клавишу 8ЫП, но не клавишу “А“. 
В потоке скан-кодов 1ЕН, принадлежащих клавише 
“А“, появится один код ААН, а затем возобновится 
поток кодов 1ЕН. Обратите внимание на то, что в 
отличие от работы в 008, где поток прописных А за- 
меняется на поток строчных а, в данном случае отпус- 
кание клавиши 8НШ не изменяет скан-кода. 
Отпустите клавишу “А“; вывод закончится кодом 
9ЕН — отпускание клавиши (1ЕН+80Н = 9ЕН). 

Проверка байтов Статуса Сдвига 
и Состояния Сдвига 

(Перед выполнением этих упражнений удалите из 
файла АІІТОЕХЕС.ВАТ все резидентные программы 
обслуживания клавиатуры, например, 008ЕОІТ.) 

Для того, чтобы увидеть изменение КОРЬАС, за- 
пустите отладчик ДЕВЫС и по подсказке в виде знака 
минус введите: 

О 40:17 Ы (дамп сегмента 40Н, смещение 17Н, 
длина 1 байт) 

На экране появится состояние байта КО_РЬАС (см. 
рис. 4) Описанные ниже действия будет проще вы- 
полнить, если его значение равно 0. Если оно не 
равно 0, то это означает, что нажата одна из клавиш 
сдвига. При необходимости переключите клавиши 
сдвига (Іпзегі, СарзЬоск, ЫишЬоск и/или 8сго11Ьоск) и 
повторите приведенную выше команду. В конце кон- 
цов вы увидите 0. Во время работы с БЕВІЮ можно 
использовать клавишу РЗ для повтора последней ко- 
манды. 


Нажмите РЗ для отображения команды О 40:17 Ы, 
но пока не нажимайте Епіег. Сначала нажмите Іпзегі 
для включения режима вставки и после этого нажмите 
Епіег. Вы увидите значение 80Н, указывающее на то, 
что режим вставки активен. Снова нажмите Іпзегі для 
его деактивации, затем по одной нажимайте другие 
фиксируемые клавиши сдвига (СарзЬоск, ЫишЬоск, 
8сго11Ьоск). Нажимая РЗ и Епіег после каждого из пе- 
реключений, наблюдайте производимый эффект. Про- 
верьте, соответствуют ли полученные значения приве- 
денным на рис. 4. 

Далее нажмите СарзЬоск и ЫитЬоск. Нажмите РЗ 
и Епіег. На этот раз вы увидите значение, являющееся 
комбинацией отдельных битов, а именно, 60Н 
(40Н+20Н). Заметьте, что указанным способом нельзя 
наблюдать состояние клавиш Сігі и АН в байте 
КВ РЬАС, так как комбинации Сігі-Епіег и АН-ЕпІег 
не генерируют возврата каретки. 

Теперь проделайте подобные операции с байтом со- 
стояния клавиш КО_РЬАС1, расположенным по ад- 
ресу 40:18 в области данных ВІ08. Введите: 

Д 40:18 Ы 

На этот раз вы увидите 0, независимо от состояния 
фиксируемых клавиш. КО РЬАСІ используется ВІ08 
для отслеживания нажатия нескольких клавиш однов- 
ременно. Для того, чтобы это увидеть, повторите пре- 
дыдущую команду, не нажимая клавиши Епіег, затем 
нажмите и удерживайте клавишу Іпзегі и нажмите 
Епіег. Вы увидите значение 80Н, указывающее на то, 
что клавиша Іпзегі находится в нажатом состоянии. 
Проэкспериментируйте с другими клавишами сдвига, 
проделывая эту же процедуру. Для выхода из отлад- 
чика введите 0. 

Как можно заметить, программа ДОТ 09Н интер- 
претирует скан-коды в виде строчных и прописных 
букв. В действительности, при нажатии на левый 8НІІ1 
программа ДОТ 09Н получает код 2АН и устанавли- 
вает (оператором ОЮ бит левой клавиши 8ЫП (бит 1) 
в байте КОРЬАС. Та же логика используется и при 
автоповторе клавиши 8ЫМ. Последовательная уста- 
новка одного и того же бита не приводит к каким- 
либо изменениям. Если нажимается клавиша “А и , то 
ДОТ 09Н обнаруживает скан-код 1ЕН, соответству- 
ющий строчной букве а. В то же самое время 
ДОТ 09Н проверяет состояние двух клавиш 8МН, про- 
сматривая содержимое байта КО_РЬАС. Программа 
обнаруживает, что левый 8ЫН еще нажат, поэтому 
строчная а становится прописной А. ' 

Прежде чем запомнить А в буфере клавиатуры, 
ДОТ 09Н проверяет бит, соответствующий состоянию 
клавиши СарзЬоск (7) в байте КО_РЬАС. Если Сар- 
зЬоск выключен, то ДОТ 09Н заносит в буфер пропис- 
ную А. Если же СарзЬоск включенг то А снова стано- 
вится строчной а, тем самым отменяя СарзЬоск. 

Далее, при отпускании левой клавиши 8НІГІ 
ДОТ 09Н обнаруживает скан-код ААН 
(ААН ° 2АН+80Н) и сбрасывает бит левой клавиши 
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8ЫН в байте КОРЬАС. При поступлении следующего 
кода 1ЕН ІЫТ 09Н обнаруживает, что левый 8ЫН 
больше не нажат (а также не нажаты ни правый 5МП, 
ни СарзЬоск) и записывает в буфер строчную а. 

Та же логика смены функций используется и при 
обработке нажатий клавиш цифровой клавиатуры. 
Если включен ЫитЬоск, то нажатие левой или правой 
клавиши 8ЫН перед нажатием клавиши на цифровой 
клавиатуре отменяет установленный статус, тем са- 
мым превращая клавиши цифр в клавиши управления 
курсором. Такая гибкость особенно полезна для поль- 
зователей 83-клавишной клавиатуры, которые обычно 
оставляют ЫитЬоск включенным. Когда необходимо 
использовать цифровую клавиатуру для управления 
курсором, то вместо переключения ЫитЬоск доста- 
точно нажать левый 8НІН и удерживать его. 

У 101-клавишной клавиатуры наряду с блоком 
цифровой клавиатуры имеются специализированные 
клавиши управления курсором. Машины с такими 
клавиатурами обычно при загрузке включают Ыит- 
Ьоск, поэтому клавиатура готова для ввода чисел. 
Однако некоторым пользователям трудно побороть 
привычку и они продолжают использовать цифровую 
клавиатуру для управления курсором. Так как при за- 
грузке устанавливается ЫитЬоск, то при первой по- 
пытке управления курсором на экране появляется 
строка цифр. Для 83-клавишной клавиатуры наблюда- 
ется обратная ошибка. Однако можно включать эти 
клавиши из ЬаІсЬ-файла, например из АЬ- 
ТОЕХЕС.ВАТ (см. рис. 5). 


КСХ 

С 

А 

МОѴ АХ, 0040 

МОѴ 08, АХ 

ХОК Вуіе Ріг [001 7] ,80 

ІЫТ20 

N ІЫЗЕКТ.СОМ 
Е 109 40 

N САР8ШСК.СОМ 
\Ѵ 

Е 109 20 

N ШМЬОСК.СОМ 
\Ѵ 

Е 109 10 

N ЗСКОЬОСК. СОМ 
АѴ 

О 


Рис.5. 

Вы можете создать файл, текст которого приведен 
ниже, и направить его в отладчик командой 

ОеЬиз < ТОССЬЕ.ЗСК 

либо ввести инструкции непосредственно, находясь в 
отладчике. Результирующие файлы ІЫЗЕКТ.СОМ, 
САРЗЬОСК.СОМ, ЫЫМЬОСК.СОМ и ЗСКОЬОСК.СОМ 


можно использовать в пакетных файлах для включе- 
ния того или иного состояния. Для некоторых расши- 
ренных клавиатур данные программы не будут вклю- 
чать соответствующие светодиодные индикаторы, 
однако результирующее состояние будет верным. 

Клавиши-переключатели 

Логика работы клавиш-переключателей (Іпзегі, 
СарзЬоск, ЫитЬоск и ЗсгоПЬоск) отличается от логики 
работы клавиш сдвига. Когда программа 1ЫТ 09Н 
встречает скан-код клавиши-переключателя, она под- 
готавливается к установке (с использованием опера- 
тора (Ж) соответствующего бита в байте КО_РЬАС1. 
Так как все биты в КЭРЬАС уже заняты, то для хра- 
нения состояния этих клавиш используется второй 
байт (см. рис. 6). Перед установкой этого бита 
ІЫТ 09Н проверяет, не был ли он установлен ранее. 

Клавиша ІпаоП. 1=нажата 

Клавиша СараСосІс 1=иажата 

Клавиша МитЬэск: 1= нажата 

| — Клавиша 5сгоІІІ_оск; 1 =иажата 

ЗИШЫИИИЕ 

СЫ-Ыит-ІлсЬ {Раисе) ' 

101 -клавишная ЗузРч 

101 -клавишная, левый АН 

101 -клавишная, правый АН 

* РИС. 6. 

Если был, то ІЫТ 09Н считает, что произошел авто- 
повтор, и не предпринимает никаких действий. С по- 
мощью программы РОКТ-А можно увидеть, что нажа- 
тие или отпускание СарзЬоск действует точно так же, 
как нажатие и отпускание любой другой клавиши, при 
этом так же посылается набор скан-кодов в случае ав- 
топовтора. Если не использовать дополнительную ло- 
гику переключения, то автоповтор приведет к непред- 
сказуемым и нежелательным переключениям. Если 
бит еще не установлен, то он устанавливается, указы- 
вая на то, что клавиша нажата. Также переключается 
бит в !Ш_РЬАС для индикации смены состояния (это 
выполняется операцией ХОК). Для просмотра содер- 
жимого КО_РЬАС в вашем компьютере вос- 
пользуйтесь рекомендациями, приведенными выше. 

Набор символов через АІ( 

Программа ІЫТ 09Н специальным образом обраба- 
тывает комбинации клавиши АН с клавишами цифро- 
вой клавиатуры. Если клавиша АН нажата (ІЫТ 09Н 
определяет это по биту 3 в КО_РЬАС), и если обна- 
руживается скан-код цифровой клавиши, то ІЫТ 09Н 
добавляет число, нарисованное на клавише, к байту по 
адресу 40:19 в области данных В 108 — АЬТ_ІЫРЫТ. 
Предыдущее значение А1ЛММР1ГГ умножается на 10 
(для сдвига десятичной точки вправо на одну пози- 
цию) прежде, чем будет добавлено новое число. При 
отпускании клавиши АН полученное таким образом 
число интерпретируется как десятичный эквивалент 
АЗСІІ-кода и помещается в буфер клавиатуры. Для 
примера, в командной строке ЕЮЗ нажмите клавишу 
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АН и, удерживая ее, нажмите и отпустите клавишу 6, 
а затем 5 на цифровой клавиатуре. Отпустите кла- 
вишу АН — на экране появится буква А, А8СН-код 
которой равен 65. При отпускании АИ ДОТ 09Н сбра- 
сывает АЬТ ДОРІІТ в 0. Если при отпускании АИ зна- 
чение АЬТ ДОРІІТ равно 0, то ввод не производится, 
что объясняет невозможность ввода нуля (А5СІІ — 
ноль) с помощью этого метода. 

Этот альтернативный метод ввода работает только с 
цифровой клавиатурой, но не с числовыми клавишами 
в верхнем ряду. Состояние ЫишЬоск не имеет значе- 
ния. Метод набора через АИ используется для ввода 
символов управления и псевдографики. 

Состояние удержания 

Если не нажаты клавиши сдвига или кла- 
виши-переключатели, ДОТ 09Н проверяет бит 3 в 
байте КО_Р1_АС1 для определения активности состо- 
яния паузы. Если этот бит установлен, что подразуме- 
вает пребывание машины в “замороженном" состо- 
янии, то он сбрасывается и ДОТ 09Н прекращает ра- 
боту. Бит 3 устанавливается нажатием комбинации 
СігІ-ЫшпЬоск на 83-клавишной клавиатуре, или спе- 
циализированной клавиши Раизе на 101-клавишной 
клавиатуре. Для “замораживания" машины ДОТ 09Н 
зацикливается сразу после установки бита паузы, 
ожидая его сброса. Сброс осуществляется при нажатии 
на любую клавишу, за исключением клавиш сдвига. 
Это происходит потому, что проверка состояния кла- 
виш сдвига выполняется раньше, чем проверка состо- 
яния бита паузы. 

Для примера, дайте команду 005 ОІК, а затем, во 
время вывода каталога на экран, нажмите 
СігІДОишЬоск на 83-клавишной клавиатуре или Раизе 
на 101-клавишной дня остановки вывода (желательно, 
чтобы каталог был большим). Теперь нажмите любую 
клавишу сдвига. Состояние изменится, однако 005 не 
возобновит вывод списка каталога. 

Комбинация клавиш СігІ-5 тоже останавливает вы- 
вод каталога, однако это реализовано не программой 
ДОТ 09Н. СігІ-5 обрабатывается и вводится в буфер 
клавиатуры точно так же, как и любой другой символ, 
а 005 уже интерпретирует ее как команду паузы. 

СігІ-АІІ-БеІ 

Комбинация С(г1-АИ-Ое1 имеет специальное назна- 
чение. При ее обнаружении в ячейку КЕ5ЕТ_РІАС, 
находящуюся в области данных ВІ05, заносится зна- 
чение 1234Н и выполняется переход на процедуру 
инициализации, которая выполняется обычно при 
включении компьютера. Программа инициализации 
проверяет КЕ5ЕТ_РІАС и пропускает самопроверку в 
том случае, если его значение равно 1234Н. Таким 
образом осуществляется “теплая" перезагрузка. 

Если вы обратитесь к байту КЭ РІАС, то заметите, 
что в нем зарезервированы биты для индикации состо- 
яния клавиш Сігі и АН, но не Оеі. Бита состояния 
клавиши Оеі нет также и в КО РІАС1. Это означает, 
что ДОТ 09Н не имеет возможности хранения состо- 


яния клавиши Оеі. Поэтому для перезагрузки необхо- 
димо сначала нажать клавиши Сігі и АП а затем Оеі. 
Порядок нажатия клавиш Сігі и АН не имеет значе- 
ния, важно только нажать Оеі в последнюю очередь. 

Сігі-Вгеак 

При обнаружении этой комбинации ДОТ 09Н вы- 
полняет несколько действий. Сначала очищается бу- 
фер клавиатуры путем установки указателя начала 
буфера равным указателю конца. Затем ДОТ 09Н 
устанавливает в 1 старший бит байта ВІ08 ВКЕАК с 
адресом 40:71Н в области данных ВІОЗ. Любая про- 
грамма может проверить значение этого бита для 
определения состояния Сігі-Вгеак. Затем ДОТ 09Н вы- 
зывает прерывание ДОТ 1ВН. Обычно ДОТ 1ВН указы- 
вает на обработчик 005, но любая программа может 
перехватить этот вектор и тем самым самостоятельно 
обрабатывать Сігі-Вгеак. Если прерывание ДОТ 1ВН 
вызывает обработчик 005, то последний устанавли- 
вает внутренний флаг Сігі-Вгеак 005. При этом лю- 
бая программа, использующая функции ввода/вывода 
005 при взведенном флаге Сігі-Вгеак (Сігі-Вгеак 005 
а не ДОТ 09Н), будет прервана. 005 отобразит на эк- 
ране значок “*С“ и выведет приглашение командной 
строки. Последнее, что делает ДОТ 09Н с 
Сігі-Вгеак — это помещает нулевой символ и скан-код 
в буфер клавиатуры. 

Ввод Сігі-С тоже интерпретируется как Сігі-Вгеак. 
Выполнение этой команды, так же как и выполнение 
СігІ-5, не является функцией ДОТ 09Н. Сігі-С обраба- 
тывается ДОТ 09Н в той же последовательности, как и 
любой другой символ, а уже 005 сама интерпретирует 
ее как команду прерывания. 

Ргіпі Зсгееп 

При нажатии комбинации 5ЫН-Ргі5сгп на 
83-клавишной клавиатуре или специальной клавиши 
РгіпіЗсгееп на 101-клавишной, ДОТ 09Н просто вызы- 
вает ДОТ 05Н для посылки дампа экрана на принтер. 
ДОТ 09Н непосредственно печатью не занимается. 

Алфавитно-цифровые клавиши 

Если ДОТ 09Н не обнаруживает специальных скан- 
кодов, то она полагает, что принятый скан-код при- 
надлежит алфавитно-цифровому символу А5СН. Для 
алфавитно-цифровых символов ДОТ 09Н проверяет со- 
стояние СарзЬоск. Затем ДОТ 09Н заносит в буфер 
как сам А5СІІ-символ, так и скан-код нажатой кла- 
виши. Это дает возможность прикладной программе 
либо прочитать АЗСН-символ, либо определить нажа- 
тую клавишу. Однако, прежде чем что-либо занести в 
буфер программа ДОТ 09Н должна проверить, есть ли 
в нём место. Если места недостаточно, то ДОТ 09Н со- 
общает об этом сигналом динамика и завершает свое 
выполнение без занесения символа в буфер. 

М. Меффорд 

(Окончание следует ) 
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Страна по имени 

ВОРІАИР 


Сегодня специальный выпуск ". КомпьютерПресс “ впервые 
посвящен продуктам одной-единственной фирмы. Но 
диапазон ее деятельности настолько широк, что мы считаем 
себя просто не вправе не уделить должного места ей в своем 
журнале, и имя этой фирмы — Вогіапд. 

И как только ухитряется Филипп Кон со своей командой 
настолько диверсифицировать свою деятельность, чтобы 
производить и превосходные оболочки, и электронные 
таблицы, и базы данных, и компиляторы — практически все, 
что только нужно пользователю персонального компьютера. 
А чего стоит последняя покупка ВогІапА, ни мало, ни много — 
сама АзНіоп-Таіе, в устойчивости которой, несмотря на 
известную неудачу с дВАЗЕ IV, не сомневался практически 
никто. 

Пять статей, включенных в этот выпуск, посвящены со- 
ответственно истории и современной стратегии фирмы, 
объектно-ориентированному программированию на ТигЪо 
Разсаі, версии ТигЪо Разсаі, работающей в среде ШпАот, 
системе управления базой данных РагаАох и генератору 
отчетов ОЬ]'есіѴЕіоп. 

Что еще хотелось бы сказать по поводу этого спецвыпуска. 
Все описываемые здесь продукты давно и весьма успешно 
продаются рядом совместных предприятий в СССР и, что 
примечательно, за советские рубли по коэффициенту, 
который значительно ниже рыночного. А сейчас по вполне 
достоверной информации ВогІапА, наконец-то, открыла собс- 
твенное представительство в Москве, и в ближайшем бу- 
дущем выйдет на советский рынок без посредников. 

А теперь, знакомьтесь — Страна по имени Вогіапй. 
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корпорация Вогіагиі Іпіетаііопаі 
(США), один из крупнейших 
производителей программных средств 
для персональных компьютеров в мире, 
активно работает на советском рынке 
с 1990 года. Количество официально 
закупленных в СССР программ Вогіапд 
измеряется тысячами, а число 
нелегально используемых копий — 
миллионами. Среди партнеров Вогіагиі в 
СССР крупнейшие совместные 
предприятия: “ Интеркв адро", концерн 
“Новинтех“, А/О “Диалог-МИФИ", 
объединение КАТ и некоторые другие 
фирмы 


Рынок программных 
средств в СССР: 

мирное наступление Вогіапд 


Программисты и пользователи часто относятся к 
программам, как к живым существам: наделяют их 
“характером**, “привычками**, серьезно оценивают 
внешний вид и “поведение**. Особенно часто характе- 
ристики из этого ассоциативного ряда применяются к 
наиболее популярным, “нравящимся** программам. На 
протяжении последних лет многократно приходилось 
слышать антропоморфные эпитеты в адрес програм- 
много обеспечения, поставляемого американской кор- 
порацией Вогіапб (ВогІапсЗ Іпіегпаііопаі, Іпс.). В чем 
причины такого отношения? Почему практически на 
каждом персональном компьютере в СССР можно 
обнаружить тот или иной продукт Вогіапб? Как, не 
впадая в апологетику Вогіапб, объяснить тот факт, что 
опросы, проводимые в СССР, постоянно показывают 
наивысший интерес советских программистов именно 
к изделиям фирмы Вогіапё? 

В предлагаемом Вашему вниманию спецвыпуске де- 
лается попытка ответить на эти вопросы, объяснить и 


проиллюстрировать отношение потребителей к про- 
дукции фирмы. В данной статье анализируются неко- 
торые причины технологического и коммерческого 
успеха корпорации Вогіапб, дается ретроспектива де- 
ятельности Вогіапб в СССР. 

Вогіапб: воплощение “американской мечты** 

Чтобы понять феномен Вогіапб на советском рынке, 
следует вернуться в 1983 год — в этом году молодой и 
предприимчивый математик, Филипп Кан (РЬіНрре 
КаЬп), предложил на американский рынок програм- 
мных средств язык программирования Разсаі по цене 
$49.95 — на порядок меньше, чем у известных фирм- 
конкурентов. В этом продукте был реализован целый 
ряд оригинальных идей, облегчавших труд программи- 
ста. Спрос превысил все ожидания! Программный 
продукт, получивший название ТигЬо Разсаі, стал 
первым громким коммерческим успехом созданной 
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Каном корпорации, которая получила название Вог- 
Іапсі Іпіегпаііопаі (в дальнейшем — Вогіапсі). 

К середине 80-х определились три стратегических 
направления деятельности Вогіапс!: языки программи- 
рования, системы управления базами данных, элек- 
тронные таблицы. 

В области языков программирования Вогіапс] штур- 
мом взял рынок программных средств, выпуская по 
неслыханно низким ценам все более и более совер- 
шенные версии ТигЬо Разсаі. Для большинства потре- 
бителей оказалось дешевле закупить легальную копию 
продукта, чем раздобыть похищенные копии програм- 
много обеспечения, а потом ломать себе голову над 
тем, где бы скопировать документацию. 

Такая коммерческая тактика Вогіапс! сохранилась и 
для других разработок, с той лишь только разницей, 
что в каждое новое изделие вкладывалось беспреце- 
дентное количество технологических новаций. Коли- 
чество проданных во всем мире копий языков прог- 
раммирования семейства ТигЬо (ТигЬо Разсаі, 
ТигЬо С, ТигЬо АззешЫег) измеряется в настоящее 
время миллионами! 

К 1990 году единственным серьезным конкурентом 
Вогіапс! на рынке языков программирования можно 
было считать, пожалуй, корпорацию Місгозоіі. Но в 
лабораториях Вогіапс! уже было разработано секретное 
оружие: набор программных средств, основанный на 
объектно-ориентированном программировании (ООП). 
Этот подход к созданию программных средств эволю- 
ционировал, начиная с 60-х годов (8ша11Та1к, Зітиіа). 
Его основные преимущества сводятся к многократному 
повышению производительности труда программистов, 
особенно, — ведущих коллективные разработки. 
Исходные тексты программ, разработанных на основе 
ООП, могут легко обобществляться разработчиками. 
Упрощается и процесс развития и дополнения дей- 
ствующих программ новыми возможностями. По сути 
дела, исходный текст программы приобретает черты 
по-настоящему отчуждаемого продукта, т.е. такого, 
который может быть легко передан коллеге, партнеру, 
подчиненному для использования и развития. Сам 
подход ООП известен достаточно давно, но 
“трудолюбивыми японцами", первыми освоившими эту 
прогрессивную технологию, оказались специалисты 
Вогіапс!. В области объектно-ориентированных средств 
программирования у Вогіапс! серьезных конкурентов 
практически не оказалось. 

Для решения задач по обработке электронных таб- 
лиц корпорация Вогіапс! выпустила продукт (^иаКго 
Рго, который по своим функциональным характери- 
стикам превосходит самые свежие версии основных 
программ-конкурентов. Кроме того, (}иаиго эффек- 
тивно работает и на морально устаревших компьюте- 
рах невысокой производительности, даже совместимых 
с ІВМ РС/ХТ (внимание, советские руководители!). 
По числу установленных копий (^иаКго Рго конкури- 
рует только с продуктами давно захватившего лидер- 
ство на этом участке рынка семейства Ьоіиз 1-2-3 
фирмы Ьоіиз Оеѵеіортепі. 


Во второй половине 80-х годов начало создаваться 
впечатление, что Вогіапс! обладает даром, сравнимым 
с прикосновением Мидаса: практически каждый про- 
граммный продукт, поставляемый фирмой, превраща- 
ется в золото — завоевывает ведущее место среди 
лучших изделий для своей категории. Так например, 
система управления базами данных Рагабох фирмы 
Вогіапс! в 1990 году опередила по количеству продаж в 
США сверхпопулярный в прошлом продукт 6ВАЗЕ 
корпорации АзЫоп-ТаІе. Технологическая победа в 
этом случае была увенчана и победой стратегической: 
в июле 1991 года было объявлено о слиянии Вогіапс! и 
АзЫоп-ТаІе. Корпорация АзЫоп-ТаІе перестает суще- 
ствовать, а все права на ее продукты и разработки пе- 
редаются Вогіапсі. И это при том, что годовой оборот у 
Вогіапс! в 1990 финансовом году был меньше, чем у 
АзЫоп-ТаІе! Коммерческая смелость и технологичес- 
кое новаторство перевесили арифметическое превос- 
ходство капитала. 

Таким образом, по всем стратегическим направле- 
ниям своего продвижения Вогіапс! сумел добиться либо 
подавляющего, либо заметного преимущества по 
отношению к продукции традиционных лидеров инду- 
стрии программного обеспечения. Количественное вы- 
ражение этого: теперь, в 1991 году, по суммарному 
обороту среди фирм — производителей программного 
обеспечения, ориентированного на ІВМ-совместимые 
персональные компьютеры, Вогіапсі (440 млн. долл.) 
уступает только МісгозоМ (1.5 млрд, долл.) и Ьоіиз 
(около 600 млн. долл.). За последние два года отмеча- 
ется двукратный рост прибыли Вогіапс!! Это успех, ко- 
торый может привести и к изменению порядка в 
“большой тройке". Отметим, что корпорации Аиіосіезк 
и ЧѴогсіРегІес!, имеющие обороты свыше 
500 млн. долл., здесь нами не рассматриваются, ввиду 
специфичности предметной области, в которой они 
ведут разработки. 

Если же учесть присущие изделиям Вогіапс! исклю- 
чительно высокие качество, надежность и эстетич- 
ность, то сложившуюся ситуацию остается охаракте- 
ризовать словами: “Вогіапс! идет!". 

Вогіапс] в СССР: воплотятся ли наши мечты? 

С первых же шагов на советском рынке корпорация 
Вогіапс! повела себя в присущем себе стиле: помимо 
высокого авторитета программных средств (ТигЬо Раз- 
саі, ТигЬо С++, Рагабох, ()иа11го Рго, ОЬіесіѴізіоп) по- 
явились весомые дополнительные доводы для привле- 
чения покупателей к продукции фирмы. Эти доводы 
можно свести к тому, что можно назвать основными 
принципами маркетинговой политики Вогіапс! на со- 
ветском рынке. 

Принцип первый: торговый паритет. Продажа про- 
граммных средств ведется без ограничений по номен- 
клатуре — самые свежие версии, обладающие высшей 
технологической новизной даже на рынке США, пред- 
лагаются одновременно для всех потребителей в 
СССР. Залежалого товара у Вогіапс! не бывает! 
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Принцип второй: учет покупательной способности. 
Приобрести все программы Вогіапб можно и за рубли, 
и за доллары, без “аннексий и контрибуций" в пользу 
долларовой номенклатуры. Рублевая цена оп-ре-де-ля- 
ет-ся в соответствии с покупательной спо-соб-но-с-тью 
молодого советского рынка, с учетом возможностей 
малых предприятий, частных фирм и индивидуалов. 
При этом, средний переводной коэффициент “по 
курсу Вог1ап(1“ близок к 10 рублям за один доллар 
цены продукта в США! 

Принцип третий: инвестиции в будущее. Зарабо- 
танные рубли расходуются на территории СССР, в 
первую очередь, на локализацию программных 
средств, проведение научно-технических мероприятий, 
рекламу, обучение и подготовку кадров. Так напри- 
мер, уже в 1991 году начались поставки наиболее по- 
пулярной СУБД Рагабох в “русифицированном" вари- 
анте. Разработка, предпринятая известным поставщи- 
ком адаптированных версий программного обеспече- 
ния зарубежных фирм, СП “Параграф" (г. Москва), 
позволяет отечественным пользователям работать с 
Рагабох на русском языке уже сегодня! Аналогичные 
работы завершаются для электронных таблиц (^иаМго 
Рго. 

Принцип четвертый: льготы пользователям конку- 
рентных продуктов (сотреііііѵе ир^габе). Для пользо- 
вателей программ-конкурентов объявлена “амнистия": 
при переходе на соответствующий продукт Вогіапб 
они автоматически получают скидку до 60%, то есть, 
обладают теми же правами, что и зарегистрированные 
владельцы предыдущей версии программного средства 
Вогіапб. 

Принцип пятый: союз с потребителем. Особое вни- 
мание в СССР корпорация Вогіапб уделяет формиро- 
ванию и поддержке движения пользователей, созда- 
нию структур, поддерживающих и развивающих связи 
фирмы-производителя и потребителей программной 
продукции. 

Действительно, любой потребитель программной 
продукции (пользователь) склонен персонифицировать 
применяемые им средства. Во многом это связано с 
интеллектуализацией процессов обработки информа- 
ции на компьютере, что неотвратимо закладывает во 
взаимодействие “человек-программа" глубокую эмоци- 
ональную основу. По-видимому, это обстоятельство 
учитывается не только при проектировании диалого- 
вых средств Вогіапб, которые славятся своей инту- 
итивностью и наглядностью, но и в определении так- 
тики фирмы в отношении связей с общественностью 
(РиЫіс геіа(іопз). Так например, Вогіапб проводит 
ежегодный международный семинар пользователей, на 
котором ведущие специалисты фирмы, начиная с са- 
мого Филиппа Кана, рассказывают о своих разработ- 


ках, выясняют тонкости восприятия их продукции со 
стороны пользователей, попросту — советуются с 
ними о перспективах развития отдельных пакетов про- 
грамм. 

Пользователи Вогіапб в СССР, 
объединяйтесь! 

В 1991 году одним из наиболее очевидных успехов 
Вогіапб в СССР из области связей с общественностью 
стало создание корпорацией совместно с инициатив- 
ной группой из числа московских программистов Ас- 
социации групп пользователей Вогіапб в СССР 
(БорАГ). Активное участие в этом процессе приняли 
Международный компьютерный клуб (МКК) и первый 
дистрибьютор Вогіапб в СССР — СП “Интерквадро“. 

Одна из неформальных целей создания Ассоци- 
ации — обеспечение советских программистов и поль- 
зователей дополнительной информацией о новейших 
технологиях в области программных продуктов, фор- 
мирование условий, позволяющих создавать конкурен- 
тоспособные программы мирового уровня с помощью 
инструментальных средств Вогіапб. Деятельность Ас- 
социации направлена на достижение информацион- 
ного паритета советских и зарубежных программистов 
и подразумевает создание комфортной “информацион- 
ной среды" для ее членов. Ассоциация является не- 
прибыльным, некоммерческим общественным объеди- 
нением. Уникальность подхода Вогіапб к работе с 
пользователями проявляется в том, что членами БорАГ 
могут стать не только зарегистрированные', но и “не- 
легальные" пользователи программных средств 
Вогіапб. 

Основные направления деятельности Ассоциации 
сближают ее с научно-техническими обществами, уже 
известными в СССР, как форма организации обще- 
ственной активности, в их числе: 

- научно-техническая пропаганда и популяризация 
инновационных подходов фирмы Вогіапб к созданию 
и применению средств программного обеспечения, 
организация и проведение массовых мероприятий в 
сфере информатики; 

- содействие распространению в СССР и за рубежом 
новых программных продуктов, разработанных с по- 
мощью инструментальных средств Вогіапб; 

- воспитание культуры легального использования про- 
граммных средств в СССР; 

- выявление и оказание содействия, включая бла- 
готворительное, перспективным, талантливым про- 
граммистам и коллективам, работающим со сред- 
ствами Вогіапб; 

- организация и координация деятельности Групп 
Пользователей Вогіапб в СССР, взаимодействие с за- 
рубежными Группами Пользователей. 

Только в первом полугодии 1991 года БорАГ и ее 
членами проведено 12 научно-технических семинаров 
с участием представителей корпорации Вогіапб и эк- 
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спертое Ассоциации (в том числе, в Москве, Ленин- 
граде, Душанбе, Архангельске, Уфе, Казани, Севасто- 
поле). 

Все члены Ассоциации бесплатно получают пери- 
одический бюллетень “БорИС“ (“Вогіапб — Иннова- 
ции Сегодня"). На его страницах публикуется новей- 
шая информация о достижениях Вогіапб, заметки об 
опыте применения продукции фирмы в СССР, пере- 
воды актуальных статей из зарубежных изданий. 

Для членов Ассоциации ежегодно проводится 
“Вогіапб-лотерея". Корпорация Вогіапб бесплатно 
предоставляет свои новейшие продукты для проведе- 
ния лотереи. В рамках Лотереи-91 среди членов Бо- 
рАГ разыграны 30 экземпляров наиболее популярных 
продуктов фирмы Вогіапб: 

- ТигЬо Разсаі 6.0 Ргоіеззіопаі; 

- Рагабох 3.5; 

- (?иа11го Рго 2.0 . 

Ассоциация проводит ежегодный Всесоюзный кон- 
курс на лучшую разработку программных продуктов, 
выполненную средствами Вогіапб — “Вогіапб-Кон- 
тест“. Цель конкурса: внедрение международных кри- 
териев оценки качества программных средств, популя- 


ризация разработок фирмы, поиск новых идей и ори- 
гинальных подходов к использованию программного 
обеспечения Вогіапб, стимулирование и реклама раз- 
работок, которые используют продукцию Вогіапб. В 
конкурсе 1990-1991 года участвовали более 300 про- 
граммных разработок советских программистов со всей 
страны. На церемонии вручения наград, которая со- 
стоялась во время II Форума Международного компью- 
терного клуба (МКК) в Центре международной тор- 
говли в Москве, 41 лучшая работа была удостоена 
Дипломов Ассоциации групп пользователей Вогіапб и 
МКК. Все дипломанты получили в качестве призов 
разнообразные (и новейшие!) продукты Вогіапб, спе- 
циально выделенные для этого корпорацией, а один из 
авторов работы, занявшей первое место, сможет со- 
вершить поездку в Калифорнию для ознакомления с 
работой программистов Вогіапб. 

Ассоциация групп пользователей Вогіапб в СССР 
(БорАГ) приглашает и Вас стать ее членом! По вопро- 
сам о вступлении в Ассоциацию групп пользователей 
Вогіапб в СССР обращаться по адресу СП 
“Интерквадро" (см. ниже), тел. 150-92-01 (дем. зал). 

А. Зотов 


ИСПА 

КОНЕЧНОЭЛЕМЕНТНЫЙ ПРОГРАММНЫЙ КОМПЛЕКС ДЛЯ ГОМ РС 



Интегрированная Система Прочностного Анализа (ИСПА) методой 
конечных элементов поможет Вам решить многие проблемы в области 
проектирования новых прочных и легких конструкций, модификации уже 
выпускающихся изделий, сократив затраты на изготовление и испытание 
опытных образцов. 

ИСПА работает на ШИ РС совместимых компьютерах в ОС М3 003 . 
и на рабочей станции БЕСТА в ОС ШИ Зузіет V. 

ИСПА зарегистрирована в ЦИФ ГосФАП. 


ИСПА позволяет решать задачи: 

* линейной и нелинейной статики; 

* динйілгаи ; 

* стационарной и нестационарной теплопроводности; 

* термоупругопластичности. 

ИСПА это: 

* 10000 узлов, 10000 элементов и 25000 степеней свободы в 

одной модели на ШМ РС; 7 

* библиотека из более, чем 40 типов 1-но, 2-х и 3-х мерных 
конечных элементов и возможность их совместного использования; 

* интерактивная векторная и растровая графика; 

* встроенный генератор конечноэлементных сеток; 

* возможность создания пространственных, моделей в системе АиІоСАБ; 

* связь с системой АиІоСАБ; 

* дружественный оконный интерфейс; 

* полный комплект печатной документации; 

* бесплатное сопровождение в течение 1 года. 



ФИРМА ’МИШИД' совместного советско-американского предприятия 'Эльба' 
адрес: 115580, г. Москва а/я 51, СП 'Эльба', фирма ’МИШИД’. 
телефон: 395-51-23. Факс: 396-42-15. 
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Р азвитие программного обеспечения 
связано с увеличением его сложности. 
При этом процесс разработки программ 
становится очень трудоемким, а их 
модификация и сопровождение — 
затруднительными. 


Введение в объектно- 
ориентированное 
программирование: 

язык ТигЬо Разсаі 



Первым шагом на пути преодоления постоянно рас- 
тущей сложности разработки программного обеспече- 
ния стала выработка принципов структурного про- 
граммирования и структурного подхода к проектиро- 
ванию программ. Модульность, структурный стиль и 
нисходящее проектирование позволили сократить 
сроки создания программ, упростить их отладку и со- 
провождение. Появились новые языки, которые пре- 
красно поддерживали требования структурного про- 
граммирования, а старые языки модифицировались до 
расширений, вписывающихся в принципы структур- 
ного программирования. 

Создание технологии объектно-ориентированного 
программирования стало вторым шагом на пути реше- 
ния указанных выше проблем. Поначалу ООП, при- 
сущее только таким специализированным языкам, как 
ЗтаШаІк и Зітиіа, не получило широкого распростра- 
нения в обыденной практике. Ранние разработки в 
области ООП были тесно связаны с исследованиями в 
области искусственного интеллекта и моделирования. 

Поиск методов преодоления сложностей создания 
больших программных комплексов и их последующей 
модификации заставил переосмыслить принципы ООП 
для широкого применения. Использование этих прин- 
ципов. по образному выражению одного из редакторов 
журнала Вуіе, “превратило программирование из ле- 
востороннего — логического, в правостороннее — 


творческое" (проводится аналогия с полушариями че- 
ловеческого мозга). Желание использовать принципы 
ООП в широкой практике привело к появлению объ- 
ектно-ориентированных расширений популярных язы- 
ков программирования. 

В настоящее время имеются объектно-ориентиро- 
ванные расширения таких языков программирования, 
как С, Разсаі и Іізр. Для компьютеров, совместимых с 
ІВМ РС, ряд фирм выпускает компиляторы языка С++ 
(объектно-ориентированное расширение С), имеются 
компиляторы объектно-ориентированного расширения 
языка Разсаі — ТигЬо Разсаі фирмы ВогІапЛ и <}иіск 
Разсаі фирмы МісгозоН. Для программирования в 
среде Ѵ(іп<1о\ѵз фирмой ТНе >ѴЬіІетѵаІег Сгоир разрабо- 
тан объектно-ориентированный язык Асіог. Выпущен 
рад библиотек объектов, таких как ОЬіесІ РгоГеззіопаІ 
фирмы ТигЬоРоѵег ЗоІЬѵаге для языка ТигЬо Разсаі, 
С++ Тооіз фирмы Кодое >Ѵаѵе и 2іпс Іпіегіасе ІіЬгагу 
фирмы 2іпс ЗоНѵ/аге для языка С++. 

Немного истории 

Впервые объектно-ориентированная техника про- 
граммирования была реализована более десяти лет на- 
зад для компьютеров фирмы Арріе, когда в 1980 году 
была выпущена объектно-ориентированная версия 
языка ЗтаШаІк. В 1985 году для компьютера Уза был 
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создан язык программирования Сіазсаі. В нем был 
объединен синтаксис языка Разсаі с понятиями клас- 
сов и методов языка ЗтаШаІк. Этот язык, совместно с 
библиотекой классов Уза Тооікіі, использовался для 
разработки программного обеспечения компьютера 
Уза. 

В 1984 году группа разработчиков вместе с Никла- 
усом Виртом, автором языка Разсаі, начала работу по 
созданию языка Оіуесі Разсаі — объектно-ориентиро- 
ванного расширения языка Разсаі. Это расширение 
основывалось не на стандартном описании языка Раз- 
саі (150 Разсаі), и не на оригинальном языке Разсаі 
(Иенсен и Вирт), а являлось расширением синтаксиса 
языка Арріе Уза Разсаі, который, в свою очередь, уна- 
следовал много свойств языка 11С50 Разсаі. Была 
также создана библиотека классов, названная МасАрр. 
Первая реализация этого проекта появилась в 1985 
году. 

В настоящее время ОЬ)есі Разсаі совместно с 
МасАрр широко используется для разработки приклад- 
ных программ для компьютеров МасіпІозЬ. 

ООП. Основные преимущества 

В чем же состоят преимущества ООП и что лежит в 
их основе? 

В действительности, при написании программ, даже 
объединяя отдельные данные в структуры и разумно 
разбивая программу на функциональные модули, про- 
граммист неминуемо сталкивается с большим количе- 
ством мелких деталей. 

ООП дает возможность отойти от мелких деталей 
программы (процедур и данных) и работать с ней, как 
с программной моделью объектов реального мира. При 
этом появляется возможность легкого перехода от 
одного уровня абстракции рассмотрения объекта (в де- 
талях) к другому (как единое целое). 

Другим преимуществом ООП является возможность 
использования ранее созданного программного обеспе- 
чения в процессе создания нового. При этом не требу- 
ется какой-либо переделки готового программного 
обеспечения и даже его перекомпиляции. 

Основу ООП составляет понятие объекта. Объект (в 
понимании ООП), объединяя в себе декларативную и 
процедурную части, моделирует некоторый концепту- 
альный или реальный объект окружающего мира. 
Программа, написанная в рамках ООП, представляет 
собой совокупность обменивающихся сообщениями 
объектов и моделирует некоторое реальное поведение 
предметов. Написание объектно-ориентированных 
программ облегчается тем, что программист создает 
программу, руководствуясь привычными понятиями 
той области, которую моделирует проектируемая про- 
грамма. 

Основа ООП — объекты 

Что такое объект и какие ему присущи свойства? 

Объект представляет собой совокупность данных и 


процедур, работающих с этими данными. Объект мо- 
жет моделировать как реальные явления, так и кон- 
цептуальные понятия, как например, классы структур 
данных: список, очередь, дерево, хэш-таблица и др. В 
программе объекты представляют собой переменные 
или константы. Переменная или константа типа дан- 
ных объект, называется экземпляром объекта. Доступ 
к полям данных объекта возможен только через про- 
цедуры-методы, определенные внутри этого объекта. 
Вызов процедуры, определенной внутри объекта, на- 
зывается передачей сообщения объекту. Объединение 
данных и процедур, работающих с этими данными в 
объекте, называется инкапсуляцией. Инкапсуляция, 
наряду со строгой типизацией, ранее присущая таким 
языкам программирования как Ада и Модула, обеспе- 
чивает защищенность полей данных объекта от не- 
предусмотренных модификаций, что в значительной 
мере повышает надежность программирования. 
Инкапсуляция гарантирует строго определенный, кон- 
тролируемый программистом набор свойств объекта. 

Другим важным свойством объектов является на- 
следование. Оно заключается в том, что вновь созда- 
ваемый объект может строиться на основе существу- 
ющего объекта-предка. При этом он наследует и мо- 
жет использовать все поля данных и методы родитель- 
ского объекта. Объекты, связанные родственными 
отношениями, образуют иерархическую структуру 
(называемую иерархией объектов), которая может 
отражать иерархическую структуру моделируемого яв- 
ления. Иерархическая структура позволяет легко пере- 
ходить от одного уровня абстракции рассмотрения 
объекта (в деталях) до другого (как единое целое). 
Пример такой структуры показан на рисунке 1. 


>Ѵіп<іош 



Рогш 

Ріеіб 


ІпІекегРіеІсІ 

ВооІеапРіеІб 

ЗігіпгРіеІб 


Рис.1. Иерархия объектов. 

На приведенном рисунке показана иерархия объек- 
тов, состоящая из базового объекта Окно ОѴіпбоѵ), на 
основе которого строится объект Форма (Рогш). Объ- 
ект Поле (Ріеіб), построенный на базе объекта Форма, 
является предком для трех объектов ЦелоеПоле 
(ІпІевегРіеШ), ЛогическоеПоле (ВооІеапРіеІб), Стро- 
ковоеПоле (ЗігіпвРіеІб). 

Наследование дает возможность расширять уже со- 
зданные объекты, придавая им необходимые новые 
свойства. Доступ к динамически создаваемым объек- 
там одного семейства (иерархий) возможен посред- 
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ством совместимых по типам указателей. Поэтому, ча- 
сто, для обеспечения совместимости указателей, раз- 
личные объекты объединяют в одну иерархию, искус- 
ственно создавая единый для всех объект-предок, ко- 
торый называют абстрактным объектом. Абстрактный 
объект стоит в вершине иерархии и служит лишь для 
обеспечения совместимости типов указателей на объ- 
екты в иерархии. Абстрактный объект, как правило, 
не содержит в себе каких-либо полей данных и мето- 
дов. 

Объект-потомок может иметь методы с аналогич- 
ными именами, что и у объекта-предка. В этом случае 
говорят, что объект-потомок переопределяет метод 
объекта-предка. Переопределение дает возможность 
передачи одного и того же сообщения экземплярам 
разных объектов. Возможность использования одина- 
ковых имен методов для различных объектов называ- 
ется полиморфизмом. 

Часто возникает необходимость использования в 
объекте-потомке ряда методов объекта-предка, 
имеющих обращения к методам, которые были 
переопределены у потомка. В этом случае возможно 
использование переопределенных методов, и такая 
возможность реализуется при помощи механизма вир- 
туальных методов. Это позволяет создавать новые 
программы с использованием уже созданных на уровне 
машинного кода. 

Язык ТигЬо РазсаІ фирмы ВогіапЛ 

Каким образом свойства ООП реализованы в объ- 
ектно-ориентированном расширении языка ТигЬо Раз- 
саі фирмы Вогіапд? 

Для определения объекта введен новый описатель 
ОШЕСТ. Он похож на описатель типа данных запись 
(КЕСОКО) с одним существенным дополнением — 
внутри него возможно определение методов (процедур 
и функций), оперирующих с полями данных этого 
объекта: 

Туре 

{Тип данных — объект) 

ОЬіесДОате = ОЬ/есі 

{Описание различных полей данных объекта) 

ОаІаРіеШКаше : ОаІеТуре; 


{Заголовки методов (процедур и функций), 
оперирующих над полями данных объекта) 
ргоседиге МеіЬскШате (Рагатеіеге) ; 

Гипсйоп МеіНосІЫаше : РипсІіопКеІитТуре; 

епсі; 

В определении объекта приводятся только заголовки 
методов. Процедуры и функции, которые реализуют 
данные методы, должны помещаться в любом месте 
раздела процедур или в секции ІМРЬЕМЕМТАТКЖ 
для объектов, определенных в единице компиляции 
ІЖІТ. Перед именем реализующей процедуры или 
функции должно стоять имя соответствующего типа 
объекта, отделенное разделителем (точкой): 


Ргосейиге ОЫесДОате.МеОгодКате; 

Ѵаг 

Ье^іп 

епф 

Определение экземпляра объекта производится в 
разделе переменных или констант путем указания 
имени экземпляра, от которого разделителем 
(двоеточием) отделяется имя типа объекта: 

Ѵаг 

ОЬіесІІпзйпсе : ОЬ)есДОате; 

Доступ к полям данных объекта возможен в любом 
месте программы, где распространяется определение 
объекта, указанием имени экземпляра объекта с отде- 
ленным от него разделителем (точкой) именем поля 
данных. Однако при этом происходит нарушение 
свойства инкапсуляции, поэтому пользоваться этой 
возможностью не рекомендуется: 

ОЬіесіІп$Іапсе.ШіаРіе1<Шате 

В случае необходимости доступ к полям данных и 
методам объекта, определенным в единице компиля- 
ции ІЖІТ, можно закрыть из других единиц компиля- 
ции (усиление свойства инкапсуляции). Для этого за- 
крываемая группа данных и методов размещается в 
конце описания объекта и перед ней указывается заре- 
зервированное слово Ргіѵаіе (при этом невозможно 
производить расширение свойств объекта, связанных с 
этими полями). 

Передача сообщения объекту (вызов метода) произ- 
водится указанием имени экземпляра объекта с после- 
дующим указанием через разделитель (точку) имени 
сообщения (метода). 

ОЪіесІІпвШісе.МеЙнхШате (Рагатеіеге) ; 

Как и в случае работы с записями, возможно 
использование оператора присоединения ЧЧІЬ для 
упрощения передачи нескольких сообщений экзем- 
пляру объекта, либо для обращения к нескольким по- 
лям данных экземпляра объекта. 

АѴііЬ ОЬіесіІпзіапсе Бо МеИмхМмпе (Рагатеіеге); 

\ѴііЬ ОЬ)есіІп5іапсе По ... ОаІаРіеІсШате ... 

Доступ к данным объекта внутри процедур, которые 
реализуют тот или иной метод, осуществляется путем 
указания имени соответствующего поля объекта. Ссы- 
латься на имя соответствующего экземпляра объекта 
или передавать его в качестве параметра не нужно, 
так как эта информация передается всем методам объ- 
екта через скрытый параметр 8е1І. Этот параметр 
представляет собой не что иное, как указатель на 
экземпляр объекта и обеспечивает все потребности 
внутренней адресации. Иногда, в случае 
возникновения неоднозначности при обращении к 
переменным внутри процедур, возможно явное 
указание имени этого параметра перед именем поля 
данных соответствующего объекта: 

5еІГЛ)аІаРіе1(Жате 


КомпьютерПресс 1 1 '91 



48 


ВВЕДЕНИЕ В ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ. ЯЗЫК ТЦЕВО РА5САІ, 


То же самое относится и к вызовам других методов 
объекта внутри процедуры или функции, реализующей 
данный метод. 

Если предполагается, что методы, вызываемые 
внутри данного метода, могут быть переопределены в 
объектах-потомках и необходимо осуществлять обра- 
щение к переопределенным методам, то возникают 
следующие проблемы. В период генерации кода ком- 
пилятор не может сформировать корректные адресные 
ссылки на необходимый метод, так как заранее неиз- 
вестно, какая процедура будет реализовывать метод — 
собственная или одна из переопределенных в объек- 
тах-потомках. Процесс установки адресных ссылок в 
период компиляции/компоновки называют ранним 
связыванием. В случае обращения к переопределен- 
ным методам процесс установки адресных ссылок 
должен происходить во время выполнения программы 
(позднее связывание). Для указания компилятору 
того, какой тип связывания необходимо использовать, 
служит зарезервированное слово Ѵігіиаі, которое запи- 
сывается после заголовка метода при описании объ- 
екта: 

ргосесіиге МеіЬосШате (Рагашеіеге); ѴіПиаІ; 

Если признак Ѵігіиаі присутствует, то будет 
использоваться позднее связывание, и соответству- 
ющий метод называется виртуальным. В противном 
случае осуществляется раннее связывание и метод на- 
зывается статическим. Если в заголовке метода появ- 
ляется признак Ѵігіиаі, то все методы в иерархии объ- 
ектов (у объектов-потомков) с аналогичными именами 
должны иметь тот же признак и аналогичный заголо- 
вок. В случае статических методов заголовок может 
меняться от потомка к потомку. 

Для обеспечения процесса позднего связывания в 
описании объекта необходимо использовать специаль- 
ный метод-конструктор, к которому необходимо обра- 
титься перед началом работы с каждым экземпляром 
объекта. Основная функция конструктора — связать 
конкретный экземпляр объекта с соответствующей его 
типу таблицей виртуальных методов объекта для 
обеспечения процесса позднего связывания. Таблица 
виртуальных методов содержит следующую информа- 
цию для каждого объекта: размер объекта и указатели 
на процедуры, реализующие виртуальные методы. 
Кроме того, в конструкторе возможно использование 
других предусмотренных программистом действий, не- 
обходимых для инициализации экземпляра объекта. 
Для метода-конструктора в его заголовке используется 
зарезервированное слово сопхігисіог: 

СогШгисіог Сопв(гис(ог№те (Рагашеіеге) ; 

Для динамически размещаемых экземпляров объек- 
тов в процедуре Ые>ѵ возможно указание вторым па- 
раметром обращение к конструктору: 

N6» (Рошіегівдіапсе, СопаігисіогШте (...)); 

Также возможно использование процедуры Ыеѵ как 
функции: 


Роіпіегігшіапсе : = ^яг(Туре№те, СопзйпсЦнШтеО); 

і 

Для корректного (в случае использования меха- 
низма совместимых по типу указателей на объект) 
освобождения памяти, занятой динамически разме- 
щенным экземпляром объекта, возможно использова- 
ние специального метода-деструктора. Помимо осво- 
бождения памяти, в деструкторе можно предусмотреть 
любые действия, связанные с завершением работы с 
объектом и освобождением памяти, занятой динами- 
ческими полями данных объекта. Для метода-деструк- 
тора в его заголовке используется зарезервированное 
слово беаігисіог: 

БеЛгисіог ОеаІгисЮгКате (Рагашеіеге); 

Компилятор автоматически подставляет в конструк- 
тор и деструктор необходимые служебные действия, 
поэтому, если нет необходимости использования ка- 
ких-либо дополнительных действий по инициализации 
и деинициализации объекта, тела соответствующих 
процедур должны быть пустыми. В процедуре Оі$ро$е 
для экземпляра динамического объекта возможно 
использование деструктора: 

Ш$ро5е(РоіпіегІп$іапсе, Без ігисйгІѴате (...)); 

В дальнейшем мы более подробно опишем различия 
между статическими и виртуальными методами, рас- 
пределение памяти под объекты, использование вирту- 
альных методов и динамических объектов. 

Д. Рогаткин 
. А. Федоров 
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Приведенный ниже словарь терминов базируется на объектно-ориентиро- 
ванном расширении языка Разсаі — ТигЪо Разсаі 6.0 фирмы Вогіапй, но 
включает при этом распространенные термины, присущие другим языкам. 

Термины объектно-ориентированного программирования 


Абстрактный объект (АЪзігасі оЬ]ес1) — 
основным назначением абстрактного объекта является 
создание базового объекта, который затем может быть 
наследован другими объектами. Экземпляры абстракт- 
ного объекта никогда не создаются. Использование аб- 
страктных объектов позволяет связать несколько объ- 
ектов в одну иерархию объектов. Синоним термина в 
языке ЗгааШаІк — абстрактный суперкласс (аЬзігасі 
зирегсіазз). 

Библиотека классов (С1а$$ ІлЬгагу) — набор 
готовых объектов общего назначения. Примером биб- 
лиотеки классов для языков ТигЬо Разсаі и (}иіск Раз- 
саі является продукт фирмы ТигЬо Роѵѵег ЗоіЬѵаге — 
ОЬіесІ РгоРеззіопаІ. 

Виртуальный метод (Ѵіхіиаі шеШой) — метод, 
адрес которого известен только в момент выполнения 
программы. Когда происходит вызов виртуального ме- 
тода, его адрес берется из таблицы виртуальных ме- 
тодов. Это называется непрямым вызовом. В языке 
ТигЬо Разсаі виртуальный метод отмечается ключевым 
словом Ѵігіиаі. 

Дерево классов (С1а$$ ігее) — термин языка 
Асіог, синоним термина иерархия объектов. 

Деструктор (Безігисіог) — специальная проце- 
дура для высвобождения памяти, занятой объектом. 
Если по завершении работы с объектом (перед его 
удалением из памяти) необходимо выполнение каких- 
либо специальных действий, они должны быть выпол- 
нены внутри деструктора. Эта специальная процедура 
может быть вызвана в качестве параметра стандартной 
процедуры Бізрозе (ТигЬо Разсаі). Деструктор объяв- 
ляется использованием зарезервированного слова бе- 
зігисіог: 
йезігисіог Бопе; 

Иерархия классов (С1а$$ Ніегагсйу) — термин 
языка ЗтаШаІк, синоним термина языка ТигЬо Разсаі 
иерархия объектов и термина языка Асіог дерево 
классов. Иерархия классов позволяет создавать 
классы-потомки существующих классов таким обра- 
зом, что классы-потомки наследуют все данные и ме- 
тоды классов-предков. Иерархия классов создается 
объявлением абстрактного объекта в вершине иерар- 
хии и присвоением этому абстрактному объекту 
общего указателя на код и данные всей иерархии. 

Инкапсуляция (Іпсар$иІа(іоп) — объединение в 
типе данных объект полей данных и методов 
(процедур и функций), работающих с этими данными. 

Класс (С1а$$) — синоним термина языка ТигЬо 
Разсаі тир данных объект. 


Конструктор (Сопзіпісіог) — специальная про- 
цедура, инициализирующая экземпляр объекта, со- 
держащий виртуальные методы, путем установки 
связи между экземпляром объекта и таблицей вирту- 
альных методов. Эта специальная процедура может 
быть вызвана в качестве параметра стандартной про- 
цедуры Ыеѵг. В ТигЬо Разсаі конструктор объявляется 
использованием зарезервированного слова сопхігисіог: 
сопзігисіог Іпіі; 

Метод (МеіНоф — процедура или функция, 
определенная внутри объекта для работы с данными 
объекта. Методу доступны данные объекта без явной 
передачи их в качестве параметров. Возможно насле- 
дование методов. Методы могут быть статическими и 
виртуальными. Для виртуальных объектов существуют 
два специальных метода — конструктор и деструк- 
тор. 

Множественное наследование (Миіііріе ІпНег- 
ііапсе) — наличие у объекта нескольких родителей. 

Наследование (Іпйегііапсе) — процесс получе- 
ния данных и методов от объекта-предка. Возможно 
многоуровневое наследование. 

Объект (ОЬіесі) — тип данных объект. Совокуп- 
ность данных и процедур — операций над этими дан- 
ными (называемых методами). Дополнительно объ- 
екты могут наследовать методы и данные объектов- 
предков. Термин объект является синонимом термина 
класс (сіазз) языка С++. 

Объекты-контейнеры (Сопіаіпег ОЬ]есІз) — 
объекты, способные хранить в себе другие объекты. 
Например: стек, очередь, дерево, динамический мас- 
сив, хэш-таблица и другие подобные структуры. 

Объект-потомок фезсепсіапі оЬіесі) — объект, 
наследующий методы и данные от объекта-предка. 

Ьосаііоп = ОЬіесЦ {« — Обьект-предок ) 

{Данные объекта и методы) 

епф 

Роіпі = ОЬіесКЬосапоп); {« — Объект-потомок) 

{Данные объекта и методы) 

епд; 

Объект-предок (Апсехіог оЬіесі) — объект, ме- 
тоды и данные которого наследует объект -потомок. 

Параметр 8е1Г (8еК Рагатеіег) — формальный 
параметр, передаваемый каждому методу. Содержит 
указатель на конкретный экземпляр объекта. 
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ВВЕДЕНИЕ В ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ. ЯЗЫК ТЫКВО РАЗСАЬ 


Переопределение (Оѵеггійе) — процесс создания 
у объекта-потомка новых методов с теми же именами, 
что и у объекта-предка, но с новыми функциями. Это 
делает возможным расширение объектов. В языке 
ТигЬо Разсаі 6.0 методы переопределяются прямым со- 
зданием новых методов с теми же именами. В (}иіск- 
Разсаі ключевое слово ОѴЕККШЕ должно быть вклю- 
чено после описания переопределенного метода: 

Туре 

РоіШ : ОЪіесКЬосаііоп) 

Соіог : Іпіевег; 

Ргосесіиге 8Но\ѵ; ОѴЕККШЕ; 

Рипсііоп СеіСоІог : Іпіе^ег; 

Ргосесіиге 8еіСоІог(Ые\ѵСо1ог : Іпіе^ег); 

ЕаО; 

Передача сообщения (Ме$за§е ра55іп§) — вы- 
зов метода для конкретного экземпляра объекта. Отли- 
чие сообщения от метода в том, что одно и то же со- 
общение может вызывать разные методы. Пример: 

СігсІе.Ога»; 

КесіапвІе.Ргаш; 

Рівигев'.Ргаѵ, 


Санкт-Петербургский филиал совместного 
сове тско -американского предприя тия 

ШТЕКЫАТІОЫАІ. МАПКЕТІЫС & 
СОЫ51Л.ТШС СОЯРОЯАТІОЫ 

предлагает программные продукты для 
компьютеров, совместимых с ІВМ рс 

1УІРФСЕДО 1.20 — пакет создания интер- 
фейса пользователя для М8 С, ТигЬо С, 
ТигЬо С++, ТигЬо Разсаі и М8 ГогЕгап-77, 
включая полноэкранный редактор окон, 
генератор исходных текстов программ и 
библиотеки поддержки; 

2(ЖБ 2.0 — защита от несанкциониро- 
ванного копирования выполняемых и тек- 
стовых файлов на жестких и гибких дис- 
ках; 

СК088 2.0 — кросс-система подготовки 
К18 Г $ШЕ48 ДЛЯ микроконтроллера 

ѴОС 3.1 — пакет перевода текстовых фай- 
лов с английского на русский и наоборот; 
К8_8ТАТ — статистический анализ и мо- 
делирование; 

ГА8Т_РКО — инструментальные средства 
для системы СЫРРЕК; 

Р ТАКЕТТ 1.3 — быстрая печать платеж- 
ных поручений; 

ОГРІСЕ — бухгалтерский учет государст- 
венных и коммерческих предприятий; 
СгПГОЕ8 — электронные справочники 
ШогЬоп Оиісіез) на русском языке по 
СУБД, языкам программирования, тексто- 
вым редакторам, сервисным программам. 

Наш адрес: 190000 Санкт-Петербург, 
бульвар Профсоюзов, 4-13. 

Телефоны: (812) 311-64-61, 311-61-30 
Факс: (812) 311-78-22 


Подкласс (8иЬс1а$$) — как и термин супер- 
класс, используется в языке ЗтаШаІк. Подкласс — это 
класс-потомок. Другими словами, Сели класс В насле- 
дует из класса А, то класс В является подклассом 
класса А. 

Позднее связывание (і-аіе Ыпсйп§) — ситуация, 
при которой адрес вызываемого метода неизвестен до 
момента выполнения программы. Адресация разреша- 
ется путем использования таблиц виртуальных мето- 
дов с адресами методов. Также возможно раннее свя- 
зывание. 

Полиморфизм (РоІутогрЬізгп) — возможность 
использования методов с одинаковыми именами для 
роботы с различными типами данных. 

Раннее связывание (Еагіу ЬігФпд) — ситуация, 
при которой адрес вызываемого метода известен в мо- 
мент компиляции/компоновки. Также возможно 
позднее связывание. 

Расширяемость (ЕхІегкііЬіІіІу) — благодаря 
свойству наследования, объекты могут быть расши- 
рены новыми функциями и/или полями данных. Но- 
вый метод изменяет или расширяет функции унасле- 
дованного метода и заменяет его в объекте-потомке. 
Возможно также добавление ряда новых методов к 
уже существующим. 

Связывание (ВігкЗіщ?) — процесс, Б результате 
которого вызывающая подпрограмма получает адрес 
вызываемой подпрограмм-!. Возможно раннее и позд- 
нее связывание. 

Статический метод (8іайс теіНой) — метод, 
вызываемый с использованием раннего связывания 
(адрес которого известен в момент компиля- 
ции/компоновки). По умолчанию все методы ТигЬо 
Разсаі являются статическими. 

Суперкласс (8ирегсІД55) — в иерархии объек- 
тов каждый класс имеет только одного непосредствен- 
ного предка, называемого “предком" или 
“суперклассом". Этот термин '«пользуется в языке 
ЗшаШаНс. 

Таблица виртуальных методов (Ѵіпиаі теіЬоб 
(аЫе) — таблица, хранимая в сегменте данных. Эта 
таблица создается для каждого объекта, имеющего 
виртуальные методы. В эт таблице хранятся адреса 
описанных в объекте виртуальных методов. 

Экземпляр (ІпБІапсе) — строго говоря, термин 
экземпляр не является специфическим для объектно- 
ориентированного программирования, но в связи с по- 
следним используется наиболее часто. Экземпляр — 
это объявленная переменная типа объект. Например, 
если имеется выражение Ѵаг А : Ьосаііоп, можно ска- 
зать, что А является экземпляром типа Ьосаііоп: 

ЬосвОоп = ОЬ]ес1; 

{Данные объекта и методы} 

епб; 

Ѵаг А : Ьосаііоп; 
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Эта статья посвящена новому 
компилятору фирмы Вогіапд — ТигЬо 
Разсаі /ог Шпдот, который позволяет 
создавать объектно-ориентированные 
программы в среде Місюзоф Шпдот. 


ТШВО РА5СА1 
РОК ѴѴ1ЫООѴУ5 


Не успели отгреметь фанфары по поводу компиля- 
тора ТигЬо Разсаі 6.0 с прекрасной оболочкой ТигЬо 
Ѵізіоп, а на улице ТигЬо Разсаі очередной праздник: 
фирма Вогіапсі выпустила компилятор для создания 
Ѵ/іпсІоѵѵз-программ — ТигЬо Разсаі для ^ішктз 
(ТР\Ѵ). 

До настоящего времени для создания АѴіпсІотѵз-про- 
грамм в основном использовался язык С (ряд приклад- 
ных программ создается на объектно-ориентированном 
языке Асіог фирмы \ѴЬйеѵ/а1ег) и большая часть раз- 
работки велась преимущественно в среде БОЗ с 
использованием ряда пакетных утилит. 

ТРАѴ — первый компилятор языка программирова- 
ния 3-го поколения, полностью работающий в среде 
АУіпбозга. В состав ТР\Ѵ включены все средства, необ- 
ходимые для разработки 'ѴѴіпскпѵз-программ, так что 
использование МісгозоН ЗБК не требуется. Необхо- 
димо отметить, что ТР\Ѵ предназначен только для со- 
здания ѴЛпбоѵ^з-программ, для создания ООЗ-про- 
грамм необходимо использовать компилятор ТигЬо 
Разсаі 6.0. Ниже приведены основные различия между 
этими двумя продуктами: 


ТР\Ѵ 

ТигЬо Разсаі 6.0 


Разработка программ 

Разработка программ 


только для \Ѵіпсіоѵѵ5 

только для БОЗ 


Среда \Ѵіпсіо\ѵ5 

Среда 008 


Объектно-ориентиро- 

Объектно-ориентиро- 


ванная библиотека 

ванная библиотека 

і 

ОЬіесГѴѴіпсІО’Л'5 

ТигЬо Ѵізіоп 


Только одна версия 

Стандартная и “профес- 

* 


сиональная” версии 


Интегрированная среда 


Интегрированная среда разработчика (ИСР), рабо- 
тающая в среде >Ѵіпс1оіѵз — наиболее выразительная 
часть нового компилятора. Весь процесс создания 


КомпьютерПресс 1 1 '91 






52 


ТШВО РАЗСАЬ РОК МТШОАѴЗ 


ѴЯшіоѵз-программы: ввод исходного текста, редакти- 
рование, компиляция, выполнение и отладка происхо- 
дит непосредственно в среде \Ѵіпбоѵз. Возможно 
одновременное открытие до 32 окон, которые могут 
быть произвольным образом расположены в рабочей 
области. Каждое окно может быть распахнуто или 
превращено в иконку. Строчное меню содержит прак- 
тически те же команды, что и меню ИСР компилятора 
ТигЬо Разсаі 6.0. Редактор поддерживает отмену и по- 
втор операций. 

Редактор может работать в двух режимах: режиме, 
совместимом с другими 'ѴѴіпбоіѵз-программами и под- 
держивающем набор команд стандарта ЗАА/СІІА, и в 
“альтернативном" режиме, поддерживающем набор 
совместимых с \ѴогсІ5Іаг команд. В этом режиме воз- 
можно создание собственных комбинаций клавиш с 
помощью специального макрокомпилятора. 

Изменение ИСР наложило свой отпечаток на ряд 
команд. Например, нажатие клавиш выполнения опе- 
рации поиска/замены приводит к появлению блока 
диалога, в котором необходимо указать ряд парамет- 
ров. Комбинации клавиш "КВ и "КК позволяют выде- 
лить блок, но любое перемещение указателя отменяет 
выделение блока; таким образом для того, чтобы пе- 
реместить блок, вместо команды "КѴ теперь необхо- 
димо пользоваться областью СПрЬоагй \Ѵіпсіоѵз. 

Благодаря тому, что ИСР работает в среде 'ѴѴіпбоѵз, 
возможно непосредственное выполнение созданной 
программы из среды — используя, как и в предыду- 
щих версиях, команду Кип. 

Расширения языка 

Похоже, стало уже традицией в каждой новой вер- 
сии вносить ряд изменений в синтаксис языка. В дан- 
ной версии фирма Вогіапб предприняла еще один шаг 
в сторону превращения языка Разсаі в язык С — была 
введена поддержка А5СК- строк. Это нововведение 
объясняется тем, что АРІ АѴішІоѵз использует именно 
такие строки. 

В ТР>Ѵ определен новый тип данных РСЬаг как 
*СЬаг (указатель на символ) и имеется возможность 
присвоения этому типу данных адреса строки: 
ѵаг 

СЬагРЬ- : РОіаг; 

СНагРіг : = Неііо, ШогШ !*; 

Помимо этого, имеется возможность ссылки на кон- 
кретный элемент такой конструкции, например, на 
третий, как на СНагРіг[3]. Также возможно объедине- 
ние строк и удаление подстрок, определенных через 
указатели. Компилятор выполняет целочисленное 
сравнение смещений этих указателей, рассматривая 
их как беззнаковые слова. Компилятор не поддержи- 
вает проверки выхода за пределы диапазона (гапде- 
сЬескіп^) при работе с этими строками. Такая про- 
верка должна выполняться программистом. В состав 
ТР\Ѵ входит модуль 5ІГІП83, включающий в себя фун- 


кции для вычисления длины строки, копирования 
строк и подстрок, объединения строк, сравнения 
строк, преобразования строк и т.п. 

С целью сокращения размера занимаемой памяти 
при использовании технологии объектно-ориентиро- 
ванного программирования в ТР>Ѵ введена поддержка 
таблиц динамических методов (ТДМ). Подробное опи- 
сание этого расширения требует отдельной статьи, 
здесь же лишь укажем, что занимаемая таблицами 
виртуальных методов память существенно сокраща- 
ется, особенно при использовании больших иерархий 
объектов. 

Введен ряд новых директив компилятора: 

- директива $С позволяет управлять атрибутами сег- 
мента кода; 

- директива $К предназначена для подключения ре- 
сурсов (иконок, меню, блоков диалога и т.п.) к при- 
кладной программе; 

- директива $Ѵ управляет генерацией про- 
лога/эпилога, специфичного для \Ѵіпс1щѵз при 
вызове подпрограмм. 

Также расширен синтаксис языка для поддержки 
создания и использования динамических библиотек 
(04.) и динамических виртуальных методов. 

Поддержка 

динамических библиотек 

>Ѵіпботѵ5 позволяет прикладным программам 
использовать отдельные модули кода, называемые ди- 
намическими библиотеками (ОШ, которые динами- 
чески компонуются к программе загрузчиком АѴіпбодѵз. 
Каждая такая библиотека может содержать большое 
количество функций. ТР\Ѵ позволяет вызывать под- 
программы, расположенные в 04 и создавать соб- 
ственные динамические библиотеки. Каждая подпро- 
грамма в 04 имеет название и индекс. Вызов 
подпрограммы может производиться как по названию 
(что происходит по умолчанию), так и по индексу. 

Для доступа к 04 (импорта) введена специальная 
директива ехіегпаі: 
ргосейиге ІшрогЮІХ; ехіегпаі ’ОІХ_Кате'; 

Создание 04-модуля заключается в описании про- 
цедур и функций библиотеки: 

НЬгагу Му04; 

{реализация процедуры и функций библиотеки} 

{ехрогіз} 

Ье^іп 

епб. 

Средство для создания ресурсов 

Помимо выполняемого кода, \ѴіпсЗо\ѵ5-программа 
может включать в себя ресурсы — иконки, меню, 
блоки диалога, курсоры, битовые изображения и т.п., 
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для визуального создания которых в состав ТРАѴ 
включено средство — ѴЛіИеѵаіег Кезоигсе Тооікіі 
(\ѴЯТ). ѴЛІТ является альтернативой Оіа1о& ЕсШог и 
другим утилитам для работы с ресурсами, включенным 
в ЗЭК. \ѴКТ на самом деле является набором редакто- 
ров, объединенных единым интерфейсом и позволя- 
ющих редактировать блоки диалога, иконки, битовые 
изображения, меню, курсоры и другие ресурсы. По- 
мимо возможности непосредственной работы с тексто- 
выми файлами ресурсов, "\ѴКТ позволяет извлекать ре- 
сурсы из файлов типа КЕ8, ЕХЕ и ОН. 

ТигЬо БеЬивдег 

для ѴѴіпскнѵз (ТТ>\Ѵ) 

При необходимости отладки программ возможен 
вызов отладчика из ИСР. Эта возможность является 
новинкой, так как раньше фирма поставляла два 
отладчика: встроенный в среду и внешний. При 
вызове отладчика (команда ОеЬивдег меню Кип) 
экран переключается в текстовый режим и появляется 
отладчик, внешне напоминающий отладчик, 
используемый в среде 005. В ТО)Ѵ добавлен ряд 
возможностей для отладки \Ѵіп(1о\ѵз-программ: 
просмотр ѴУіпбошз-сорбщений, локальной и глобальной 
“кучи“, просмотр модулей, загруженных ѴѴіпсІоѵѵз, и 
отладка динамических библиотек ШІХ). Обладая, с 
одной стороны, удобством при отладке "Мп Под- 
программ, ТО\Ѵ не позволяет параллельно выполнять 
никаких АѴіпПоѵѵз-программ и даже не позволяет 
переключать задачи клавишами Сігі-Езс и АИ-ТаЬ. 

Разработка программ 

ТРАѴ предоставляет возможность создавать >Ѵіп- 
Ноѵѵз-про граммы тремя способами, в зависимости от 
требований к программе и опыта разработчика. При 
необходимости быстрой переделки программ, работав- 
ших в текстовом режиме в среде 008, можно исполь- 
зовать модуль ''УіпСКТ. Этот модуль обрабатывает вы- 
зовы процедур КеасИп, Ѵгііеіп и СоІоХѴ. Модуль не 
поддерживает меню, и для того, чтобы закрыть окно 
по окончании работы программы (если оно не закрыто 
пользователем), требуется вызов специальной проце- 
дуры АѴіпСКТБопе. Ставший классическим пример с 
выводом сообщения “Неііо, ѵог1<1!“ в данном случае 
выглядит следующим образом: 

рговгаш \ѴіпНе11о; 
изез АѴіпСгі; 

Ве^іп 

АѴгііеІп ( Неііо, ^ѴогіаГ); 

ЕпН. 

Отметим, что наличие только одной строки — иве® 
ѴіпСгІ — делает программу, работающую в ЭОЗ в 
текстовом режиме, >ѴіпПо«з-программой. 

Для создания более профессиональных прикладных 
программ в состав ТРѴ/ входит объектно-ориентиро- 
ванная библиотека классов ОІцесШіпскшв. Интер- 


фейс с этой библиотекой более простой, чем с ТигЬо- 
Ѵізіоп, и она также проще в изучении и использова- 
нии. Основной класс библиотеки — класс ТАррНса- 
Ііоп, наследник которого является текущей приклад- 
ной программой. Программа с использованием ОЪ- 
ІесОУіпёоФЗ может выглядеть следующим образом: 

ргодеат АѴтНеІІо; 
изев ѴГОЬ]есВ; 

»Уре 

ТОето = оЬ]есі(ТАрр1іса!іоп) 
ргоседиге ІпііМаіпѴГішІош; ѵігіиаі; 
епд; 

ѵаг 

\ѴііШето : ТОето; 

ргосейиге ТОето.ІпШаіпѴѴтдоѵу; 

Ье^іп 

МатѴГтсІст : = Ые\ѵ(РѴт<1а\ѵ,Іпі1(пі1,'Не11о!')); 
еші; 

Ве^іп 

АѴІпОето.ІпіК"): 

\ѴігШето.Кип; 

\Ѵ1пОето.Оопе; 

Еші. 

Как видно из приведенного примера, у ОЬуесіѴѴіп- 
(Іоѵѵз много общего с ТигЬо Ѵізіоп. Ряд классов и 
общая организация похожи, но перенос созданных 
программ из ООЗ-среды в \Ѵіпбоѵз-среду требует су- 
щественной переделки. 

Если же есть необходимость в написании программ, 
использующих вызовы )Ѵіпс1о\ѵз-функций напрямую 
(например, для переделки программ, написанных на 
языке С с использованием МісгозоН ЗОЮ, в состав 
ТР)Ѵ включен модуль ІУіпРгосз. Полный пример про- 
граммы, использующей >Ѵіп<Іо>ѵз АРІ, занимает много 
места. Ниже показан ее фрагмент — процедура >Ѵіп- 
Маіп: 

ргосейиге ѴДпМаія; 

Ѵаг 

ѴѴіпсіода : ШѴпа; 

Меззаде: ТМзв; 

Сопзі 

АѴішІоѵСІазз : ’ПѴпйСІазз = ( 

Зіуіе : 0; 

ІрІпАѴпгіРгос : @\ѴшдошРгос; 
сЬСІзЕхи-а : 0; 
сІЛѴпдЕхІга : 0; 

Ыпзіапсе : 0; 

Ысоп : 0; 

ЬСигзог : 0; 

ЬЬгВаск^гоиші : 0; 

ІрзгМепиКате : АррЫате; 

ІрзгСІаззЫате : АррЫате; 

) 

Ье^іп 

И НРгеѵІпзІ = 0 Йіеп 
Ьевіп 

^ѴішІоѵі'СІазз.ЫпзІапсе : = Шпзіапсе; 

>УішісгагС1аз8.Ысоп : = 

Ьоасіісоп (0,1<И_АррНсаЙоп) ; 

МѴшйоѵрСІазз.ЬСигзог : = 

Ьоа<1Сигвог(0,і(іс_Агпяѵ) ; 
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ѴГтдо«С1а$$.ЬЪгВаск8П)ипд : = 
СеіЗІоскОІфсІ(\ѵЫіе_Вги$1і) ; 
іГ поі КевюіегСІаззОѴіпдоѵѵСІавв) Йіеп 
НаИ(255); 

епд; 

АѴіпдоѵѵ : = СгеаІеѴГтдоѵѵІ 
АррЫагае, 

Неііо, \Ѵог1д', 

\ѵз_Оѵег1арред\Ѵіпдо\ѵ, 

с\ѵ_ШеПеІаи11, 

сш_У8еОеГаиИ, 

оѵШеОеГаиІІ, 

О, 

О, 

НІіміапсе, 

пі1); 

5Ъо\ѵ\Ѵтдо«'(\Ѵіпдо\ѵ, СтдЗНоѵѵ); 
Чрс1аІе\Ѵіпсіо\ѵ (\Ѵіп0о\ѵ) ; 

\ѵЫ1е ОіеМе.«а8е(Мемаёе,0,0,0) до 
Ъе^іп 

ТгапзІаіеМеааазе (Меаааве) ; 
ОіараісНМеаааве (Меззаве) ; 
епд; 

НаІКМеззаяе.шРагат) ; 
епд; 

Ье^іп 

ЛѴіпМаіп; 

епд. 


Заключение 

Снижение трудоемкости разработки прикладных 
'ІѴіпдоѵѵз-программ на ТР\Ѵ по отношению к С можно 
сравнить с соотношением сложности создания ООЗ- 
программ на языках высокого уровня и на ассемблере. 
Использование объектно-ориентированного подхода и 
библиотеки ОЬіесОѴіпдоѵѵз существенно сокращает 
время, требуемое на разработку \Ѵіп<іо\ѵ5-программ. 

Можно выделить несколько категорий 
пользователей ТР\Ѵ: 

- программисты, использующие ТигЬо Разсаі и жела- 
ющие создавать АУіпсіотѵз-программы; 

- программисты, ранее использовавшие ТигЬо Разсаі и 
перешедшие на МісгозоН С для написания Ѵіпдщѵз- 
программ; 

- программисты, не удовлетворенные разработкой 
ѴЛпдо\ѵз-программ с использованием Місгозоіі ЗОК; 

- программисты, использующие средства разработки 
типа ТооІЬоок, не удовлетворенные низкой скоро- 
стью работы этих средств; 

- программисты, которым необходимо перенести про- 
граммы, созданные с использованием ТигЬо Ѵізіоп, в 
среду МісгозоН АѴіпдотѵз; 

- программисты, использующие язык РАЬ СУБД Рага- 
дох, желающие создавать АѴіпдо\ѵ5-программы, 
используя библиотеку Рагадох Еп^іпе 2.0. 

А. Федоров 


Фирма ІВМ выпустила новую 
серию персональных компьюте- 
ров для мультимедиа. Эти изде- 
лия будут продаваться под мар- 
кой “Шіішедіа." ІВМ РЗ/2 ІЛіі- 
шедіа Мобеі М57 ЗЬС — это 
первый компьютер Регзопаі Зуз- 
Іет/2 (РЗ/2) со встроенными 
устройствами для мультимедиа и 
“самым быстрым 386 процессо- 
ром“. Продажа системы начнет- 
ся в марте 1992 г. Стоить она 
будет 5995 долларов. 

ІВМ РЗ/2 АсІіопМедіа II — 
набор адаптерюв для ввода и вы- 
вода цифрового видео- и аудио- 
сигналов. Устройство будет про- 
даваться по цене 1995 долларов 
в двух версиях — для Місго 
СЬаппеІ АгсЬИесІиге (МСА) и 
для Іпбизігу Біапбагб АгсЬНес- 
Іиге (ІЗА). Дополнительно мож- 
но приобрести пакет улучшения 
качества введенного изображе- 
ния и программную систему для 
разработчиков за 890 и 510 дол- 
ларов соответственно. 


ІВМ РЗ/2 ТѴ — устройство, 
которое будет состоять из видео- 
адаптера, тюнера, динамика и 
программ. Начнет продаваться 
за 495 долларов с 27 марта 
1992 г. 

ІВМ РЗ/2 ТѴ позволяет одно- 
временно смотреть до 70 телеви- 
зионных программ на экране 
РЗ/2, а новый адаптер 
Р-Соиріег позволяет передавать 
живое изображение через ло- 
кальную сеть Токеп Кіп§. 

ІВМ РЗ/2 ТоисЬЗеІесІ — сен- 
сорный экран. 12-дюймовая мо- 
дель стоит 670, а 19-дюймо- 
вая — 850 долларов. 

И еще ІВМ обещает выпус- 
тить учебный мультимедиа-диск 
для безработных. 

ЛѴеи ъЪуіез Ме\ѵз ЫеЬѵогк, 
18 ОсІоЪег 1991 

Фирма Зеа^аіе ТесЬпоІо^у 
объявила о крупных финансовых 
убытках — 47.8 миллиона дол- 


ларов — в этом квартале. Объем 
продаж, равный 620 миллионам 
долларов, остался практически 
на уровне предыдущего кварта- 
ла. Официально убытки относят 
на счет реорганизации компа- 
нии. 

Как сообщает ОРІ, Дэвид 
Митчел, сооснователь фирмы, 
неожиданно подал в отставку 
20 сентября после 12 лет работы 
в фирме. 

При попытке реорганизации с 
фирмы было уволено 1200 чело- 
век в июле (18% персонала), и 
еще 450 человек в августе. 

Как и фирма Соппег 
Регііегіаіз, также объявившая об 
увольнениях, Зеа^аіе объясняет 
все свои проблемы экономичес- 
ким спадом, хотя, видимо, война 
цен между Зеа^аіе, Соппег и 
Оиапіит также сыграла свою 
роль. 

ЫетЬуІез Ыеш ЫеЬѵогк, 
18 ОсІоЪег 1991 
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При анализе прикладного программного обеспечения принято 
выделять электронные таблицы, текстовые редакторы, 
программные средства связи, системы управления базами 
данных и графические редакторы. Попытка отнести ОЬ]'ес( 
ѴЪіоп к одному из этих классов вызовет некоторое 
затруднение, так как он является представителем 
интегрированного программного продукта, одной из 
характерных черт которого является 
многофункциональность. 


ОЬіесТѴі$іоп: 
первые впечатления 


Сегодня на рынке программных средств существуют 
и продолжают появляться пакеты полифункциональ- 
ного характера. К ним в первую очередь можно отне- 
сти пакеты для деловых приложений, — Рогш Ріііег, 
РегРогт, ЛеІРогт. Они предназначены для генерации 
форм документов, особым образом структурированной 
информации (бланков, счетов, справок и т.п.), упро- 
щения ввода и обработки информации в них, а также 
ведения архивов. 

Такие пакеты сочетают в себе возможности тексто- 
вых, графических редакторов, электронной таблицы и 
рассчитаны на пользователей, не являющихся профес- 
сионалами в компьютерной области. К деловым паке- 
там относится и пакет ОЬ]ес( Ѵізіоп, который пред- 
ставляет собой нетрадиционное соединение генератора 
форм с АѴѴЗІѴ'ѴС-интерфейсом и развитого набора 
математических, экономических и прочих функций. 

Пакет предназначен для: 

- создания и редактирования форм; 

- управления формами; 

- просмотра и вывода на печать форм. 

Судьба любого программного продукта целиком и 
полностью зависит от его реальных свойств, характе- 


ристик и отличий от других пакетов идентичного фун- 
кционального назначения. В чем же состоят эти отли- 
чия у ОЬ]ес1 Ѵізіоп? 

Во-первых, и это определяет многие свойства, ОЪ- 
]ес! Ѵізіоп работает в среде АѴіпйотѵз 3.0, что обеспе- 
чивает стандартный графический интерфейс и разде- 
ление ресурсов компьютера. С точки зрения пользова- 
телей к преимуществам "ѴѴішіоѵѵз 3.0 можно отнести: 

- представление информации в удобном для воспри- 
ятия виде; 

- большую защищенность системы от несанкциони- 
рованных действий, что позволяет непрофессиональ- 
ным пользователям избегать “рискованных" ситу- 
аций; 

- широкий выбор драйверов принтеров с минимальной 
затратой времени на их установку; 

- практически неограниченный выбор палитры цветов 
изображения и фона; 

- простота установки и настройки пакета; 

- автоматический поиск файлов на дисках; 

- создание пиктограмм в среде АѴіпбодѵз. 

- широкие текстовые и графические возможности, в 
том числе: 
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ОВ.ГЕСТ ѴІЗІ(Ж: ПЕРВЫЕ ВПЕЧАТЛЕНИЯ 


выбор шрифтов, их стилей и размеров; 
управление расположением текста; 
выбор линий различной толщины, прямоугольников 
с различной степенью заштрихованности; 
копирование, удаление перемещение, выделение 
части текста или рисунка. Сложные рисунки могут 
быть созданы в АѴіпскиѵз РаіпіЬгизН, а затем пере- 
несены в ОЬіесІ Ѵізіоп. 

Вторая особенность состоит в том, что работая в 
Оі^есі Ѵізіоп, вы можете присоединить форму к вне- 
шним данным из файлов следующих типов: А5СІІ, 
Рагабох, 6ВА5Е, Вігіеѵе, БОЕ ШОЕ — формат дина- 
мического обмена данными с другими приложениями 
\Ѵіпбо\ѵз, например, Ехсеі, \Ѵогб, ІтабеЕсШ, Місго- 
йгаГх, Місгоегаіх Оезідеіег, Согеі Эга\ѵ). 

Причем после подсоединения внешних данных, 
дальнейшая работа с ними идет по соглашениям про- 


граммы, создавшей эти файлы. Это позволяет исполь- 
зовать уже имеющийся опыт работы с другими при- 
кладными программами, и ослабляет влияние чрезвы- 
чайно мощного фактора, исторического императива, 
которым в основном и объясняется нежелание многих 
пользователей изучать новое программное средств’о. 

Мощным инструментом, отличающим О^есі Ѵізіоп 
от других “деловых** пакетов, является возможность 
включения в форму стандартных процедур и описания 
процессов заполнения форм. Причем по желанию 
можно определить, какая часть данных будет зано- 
ситься автоматически. Иными словами, пользователь 
получает возможность описать логику заполнения 
формы, используя в качестве средства формализации 
лишь графическое представление процесса, что в тер- 
минологии ОЬіесІ Ѵізіоп называется “построение де- 
рева решений**. Эта процедура может включать про- 


Официальный партнер фирмы ЫОѴЕ^ ШС. 
совместное предприятие ИНТЕРПРОКОМ и 
агентство КомпьютерПресс 
планируют издать в начале 1992 года 

каталог продуктов фирмы ЫоѵеІІ Іпс. 

Каталог объемом около 400 страниц богато иллюстрирован и 
состоит из нескольких глав, в которых описываются 
функциональные возможности продуктов фирмы, а также их 
характеристики, требования к ним со стороны аппаратных и 
программных средств, рекомендации по их использованию. 

В приложении приводится словарь терминов. 

Книга необходима в первую очередь поставщикам 
программных и технических продуктов ЫоѵеІІ. Также она 
будет полезна широкому кругу пользователей персональных 
компьютеров и локальных вычислительных сетей. Каталог 
необходим как пользователям, уже длительное время 
работающим с локальными сетями, так и пользователям, 
которые поставлены перед проблемой выбора программных 
и аппаратных средств для организации сетей. Пользуясь 
данным каталогом, пользователь сможет правильно выбрать 
тип сетевой операционной системы, программные средства 
ее окружения, в том числе коммуникационные средства, 
технические средства, необходимые для организации 
локальных сетей. 

Изданный на уровне мировых стандартов, этот каталог 
будет стоить всего 195 рублей. 

Заказы от частных лиц и гарантийные письма от 
организаций присылайте по адресу: 

113093 Москва, а/я 37 
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стое множество операций, подобных сложению и вы- 
читанию чисел и более комплексное, с проверкой раз- 
личных условий перед вычислением значений и 
использованием логических выражений, где в качестве 
операндов выступают значения данных, функции или 
имена полей (элементов формы). 

Процессу создания дерева решения обязательно 
предшествует процесс определения всех полей, кото- 
рые будут выступать в качестве вершин дерева. Поле 
можно создать как средствами Оіуесі Ѵізіоп, так и с 
помощью внешнего источника. 

Область применения пакета ОЬ)ес1 Ѵізіоп обширна, 
начиная с обычного делопроизводства, занимающего 
достаточно почетное место в любой области знания, и 
кончая, например, педагогикой. 


К недостаткам пакета ОЦесі Ѵізіоп можно отнести 
повышенные требования пакета к техническим харак- 
теристикам компьютера, что, на наш взгляд, и будет в 
первое время некоторым ограничением в распростра- 
нении пакета на советском рынке. При работе пакета 
требуется ІВМ РС на микропроцессорах Іпіеі 286, 386, 
486, среда МісгозоН \Ѵіп<1оѵз 3.0, объем оперативной 
памяти не менее 1 Мбайта и около 1-5 Мбайт памяти 
на винчестере. 

Испытания пакета проводились на компьютере со 
следующими характеристиками: РС/АТ 386, 25 МГц, 
8 Мбайт оперативной памяти, 122 Мбайта на винче- 
стере, ЗирегѴСА-графика. 

Л. Струкова 


ПУБЛИЧНАЯ ЭЛЕКТРОННАЯ БИБЛИОТЕКА 

Публичная Электронная Библиотека — это избранная коллекция гибких дисков, 

содержащая сотни новых некоммерческих программ типа РлЫіс Вошаіп и ЗЬагелѵаге. 

Публичная Электронная Библиотека — это демонстрационные и оценочные версии 

программ, тексты, документация и другие полезные материалы. 

Публичная Электронная Библиотека — это новый каталог каждые два месяца. 

Публичная Электронная Библиотека — это свободное использование предлагаемых 

программ и умеренная плата для частных лиц, организаций, предприятий и учреждений. 

В нашей коллекции: 

удобный и быстрый ре дактор С^Есііі Айѵапсеб, широко используемый программистами- 
профессионалами в США. При объеме 47 Кбайт имеет фантастические возможности; 

база данных несекретных сведений Центрального Разведывательного Управления. 
Множество сведений, которые невозможно найти в справочниках и энциклопедиях; 

обучающая демо-версия пакета Гох-Рго, «знакомящая с основными возможностями и 
приемами работы с СУБД Гох-Рго; 

демонстрационные программы из США для брокеров и биржевиков. Полезны также 
разработчикам отечественных программ, так позволяют использовать накопленный 

профессионалами Запада опыт; 

музыкальный генератор Ріапотап — прекрасное умное развлечение. Позволяет вставлять 
музыкальные фрагменты в любые прикладные программы. 

И МНОГОЕ, МНОГОЕ ДРУГОЕ В ПУБЛИЧНОЙ ЭЛЕКТРОННОЙ БИБЛИОТЕКЕ 

Одним словом. Публичная Электронная Библиотека — это то, что Вам нужно.' 

Публичная Электронная Библиотека поставляется малым предприятием " Такт ". 

Чтобы получить каталог Публичной Электронной Библиотеки, нужно перечислить на счет М 468802 в 
Коммерческом банке "Днепр" г. Смоленска, МФО 258584, указав в платежном поручении "За текущий выпуск 
каталога", и прислав нам письмо с Вашим точным почтовым адресом, номером телефона и именем, фамилией и 
должностью лица, сделавшего заказ. Просьба приложить к письму копию платежного поручения либо просто 
указать его номер и дату. 

Адрес: 214036 Смоленск, а/я 248, МП "Такт” 

Телефон для справок: ( 081 00 ) 5-58-05 
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ПАРАДОКСАЛЕН ЛИ РАКАООХ? 



Т^і.оглощение Вогіапсі корпорации АьЫоп 
Таіе вызвало не менее, чем шок в рядах 
поклонников йВА8Е. Примерно такое же 
чувство испытали и мы. Свернет ли 
Вогіапсі все работы, связанные с 
продолжением разработки линии йВА5Е, 
или нет — пока неизвестно. Но судя по 
всему, в сфере баз данных происходит 
смена поколений, и поэтому мы спешим 
представитъ нового лидера — СУБД 
Рагадох. 


Парадоксален ли Рагасіох! 


"Я гений, парадоксов друг..." 

А. С. Пушкин 

ц 

Рагасіох — первое знакомство 

Система управления базами данных Рагасіох явля- 
ется гибким современным средством построения и ве- 
дения реляционных баз данных, снабженным удобным 
диалоговым интерфейсом, языком программирования и 
средствами автоматизированного создания отчетов. 

Коммерческий успех Рагасіох определился, начиная 
с версии 2.0, когда СУБД поставлялась компанией 
АЫ5А ЗоПѵѵаге. Приобретение этой фирмы одним из 
ведущих производителей программного обеспечения, 
корпорацией Вогіапсі, привело к значительному рас- 
ширению возможностей и улучшению пользователь- 
ских характеристик Рагасіох за счет применения соб- 
ственных технологических новаций Вогіапсі (версии, 
начиная с Рагадох 3.0). 

В целом, по оценкам многих специалистов, Рагадох 
приобретает черты стандарта де-факто современной 
информатики в области баз данных, приходя на смену 
семейству дВазе. 

Причиной этому являются следующие весомые пре- 
имущества Рагадох: 

- высокая производительность; 

- простой и наглядный метод построения запросов по 
образцу ((}иегу-Ьу-Ехатр1е); 


- средства графической визуализации данных; 

- ведение журнала СУБД; 

низкие требования к ресурсам компьютера 
(благодаря технологии ѴК.ООММ); 

- наличие интерфейса со многими типами сетевых 
серверов баз данных (пакеты 8(}Ь Упк); 

- возможность (с помощью Рагадох Епгіпе 2.0) созда- 
ния прикладных программ обработки баз данных на 
языках высокого уровня типа МісгозоРІ С 5.1, ТигЬо 

С++, ТигЬо С 2.0, ТигЬо Разсаі. 

Удобство и надежность эксплуатации Рагадох в ло- 
кальной сети позволяет использовать его как высокоп- 
роизводительное оконечное средство доступа к удален- 
ным данным, включая обращение к базам данных на 
больших ЭВМ. 

По данным независимой организации Зоійѵаге РиЬ- 
1ізЬіп8 Аззосіаііоп, доля Рагадох среди применяемых в 
США СУБД увеличилась за первые 5 месяцев 1990 
года более, чем в два раза и достигла 20%. В мае 
1990 года 40% вновь приобретаемых СУБД пришлось 
на Рагадох — больше, чем у любого из конкурентов. 
К концу 1990 года Рагадох захватил 34.5% рынка 
СУБД для ІВМ-совместимых компьютеров — больше 
любой другой СУБД в США. 

Очевидно, что такие убедительные показатели не- 
минуемо приведут ко все более широкому распростра- 
нению легальных (как и пиратски похищенных) ко- 
пий Рагадох в нашей стране. 
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Общие впечатления разработчика 

Сравнительные характеристики СУБД в основном 
совпадают в различных статьях и обзорах, посвящен- 
ных базам данных. Действительно, Рагабох — удо- 
бная, мощная, хорошо продуманная и изящно скон- 
струированная система, обеспечивающая эффектив- 
ность труда программиста и возможность создавать 
эффективно работающие приложения. Авторы наде- 
ются, что некоторые отмеченные недостатки текущих 
версий со временем будут устранены и Рагабох будет 
расширен именно теми возможностями, нехватка ко- 
торых кажется столь очевидной. 

Главным парадоксом Рагабох является, на наш 
взгляд, сочетание простоты и удобства с широким на- 
бором функциональных возможностей обработки дан- 
ных. 

Работая в диалоговом режиме меню (без програм- 
мирования) можно создать довольно сложную систему 
обработки данных, включающую средства ввода и ре- 
дактирования входных документов, поиска и обра- 
ботки данных и получения разнообразных выходных 
документов. Диалоговый интерфейс Рагабох нагляд- 
нее, чем, например, подсистема АззізіапІ СУБД 
6ВА5Е III Ріиз. Пользователь в каждом режиме полу- 
чает доступ к крупному функциональному блоку с по- 
нятным входом и выходом, а не к элементарной опе- 
рации, как в 6ВА5Е. Объяснение простое: в Рагабох 
диалог ориентирован на удобство работы, в то время 
как в 6ВА5Е — на простоту преобразования в ко- 
манды этой СУБД. 

Достоинством диалогового монитора Рагабох явля- 
ется активное и единообразное использование во всех 
режимах наряду с иерархическими меню функци- 
ональных ключей и СТКЕ/АІЛГ-клавиш. 

Для описания структуры базы данных достаточно 
заполнить простую двухколоночную таблицу, указав 
имена и типы полей. Дополнительное удобство — 
возможность использования структуры уже существу- 
ющей таблицы в качестве отправного пункта при со- 
здании новой. 

После описания структуры можно разработать эк- 
ранные формы для ввода и редактирования данных 
или непосредственно начинать ввод, используя стан- 
дартные формы табличного или бланкового типа. При 
создании экранных форм пользователь может управ- 
лять размещением полей на экране, заданием поясня- 
ющих текстов, выбором цветовой палитры для экрана 
или его частей. Существует возможность связки . в 
одной форме нескольких таблиц по составному ключу. 
При этом допустимы связи между записями типа 
“один-к-одному“ или “один-ко-многим“. Возможно 
формирование значений некоторого поля данных по- 
средством выбора значения из домена (таблицы-спра- 
вочника). 

При вводе и коррекции данных могут использо- 
ваться до 16 форм ввода, связанных с текущей табли- 
цей. Одновременно можно обрабатывать несколько 
форм, связанных с разными таблицами. 


Язык запросов вызывает немой восторг программи- 
ста. В Рагабох реализован практически полный язык 
запросов (}ВЕ. Синтаксис его близок к специфика- 
циям фирмы ІВМ и публикациям автора языка, 
М.Злуфа (М.2І00І). С помощью (}ВЕ можно реализо- 
вать сложнейшие операции поиска и обработки дан- 
ных. Следует отметить, что процедурные, рассчитан- 
ные на программиста средства поиска, например, в 
СНррег или РохЬазе функционально беднее, чем дек- 
ларативные (непроцедурные) средства (}ВЕ в Рагабох. 

Проведенные нами проверки показали, что оценки 
производительности поисковых средств Рагабох, по- 
стоянно обеспечивающие ему одно из первых мест по 
скорости поиска в сравнительных обзорах СУБД для 
персональных компьютеров, вполне соответствуют 
действительности. 

Отметим, что фирма-разработчик считает диалого- 
вые возможности Рагабох средствами, ориентирован- 
ными на пользователя-непрограммиста. Американские 
программисты, конечно же, имеют в виду американ- 
ских пользователей и сложившуюся в США систему, 
при которой в подготовку сотрудников фирмы к при- 
менению автоматизированных рабочих мест вклады- 
ваются огромные средства. В нашей стране, за исклю- 
чением редких случаев, между пользователем и 
“голой" СУБД должен стоять программист, созда- 
ющий адекватные уровню подготовки данного пользо- 
вателя средства общения. Поскольку разрабатывать 
десятки новых приложений программированием “в 
лоб“ неоправданно, возможности развития программ в 
Рагабох мы будем оценивать не только с точки зрения 
написания конкретных приложений, но и создания 
инструментальных средств. 

В Рагабох реализован высокопроизводительный и 
гибкий генератор отчетов, позволяющий создавать вы- 
ходные документы табличного и анкетного типа. По- 
мимо стандартных для многих генераторов отчетов, в 
Рагабох реализованы следующие возможности: 

- вычисляемые поля отчета; 

- многотабличные отчеты; 

- вложенные группировки и подсчет итогов; 

- получение более широких, чем каретка принтера, 
выходных документов (с выводом по частям). 

В целом, встроенный генератор отчетов Рагабох со- 
поставим по функциональным возможностям и про- 
стоте использования с таким специализированным па- 
кетом, как Кеіаііопаі Кероіі ЛѴгііег фирмы Сопсепігіс 
Оаіа Зузіешз (последний работает с файлами 6ВА5Е). 

Средства разработки сложных приложений 

Для разработки приложений Рагабох имеет встро- 
енный язык программирования РАБ. В сущности, РАЬ 
объединяет два языка — язык клавиатурных макроко- 
манд и собственно систему программирования. Любую 
последовательность клавиш, использованную в про- 
цессе диалога с системой, можно сохранить в файле В 
виде программы-макрокоманды и затем выполнить не- 
обходимое число раз. Язык программирования позво- 
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ПАРАДОКСАЛЕН ЛИ РАКАООХ? 


ляет объединять такие макрокоманды, а также вклю- 
чать собственные команды и функции языка. В РАЬ 
реализованы необходимые управляющие конструк- 
ции — условия, ветвления, циклы. В языке существует 
механизм использования процедур со средствами пе- 
редачи параметров и возврата значений. Данные в 
языке представляются полями таблиц базы данных 
или переменными. Тип поля базы данных определя- 
ется при его создании и остается в программе неиз- 
менным. Тип переменной определяется типом присво- 
енного ей значения и может быть изменен оператором 
присваивания. Простая переменная может быть сим- 
вольного типа, типа “дата“, логического типа и одного 
из числовых типов — зНогІ іпіе^ег (16-битное целое со 
знаком), сиггепсу (для денежных сумм — число с 
двумя десятичными знаками) и геаі (переменная дей- 
ствительного типа двойной точности). Возможно 
использование одномерных массивов. Компоненты 
массива могут быть различных типов. Переменные в 
процедурах могут иметь локальные или глобальные 
области действия. 

Команды РАЬ обеспечивают выполнение 
“крупноблочных** операций Рагабох — одной-двумя 
командами можно обеспечить просмотр и редактиро- 
вание базы данных по любой из созданных экранных 
форм, выполнение запросов, подготовку отчетов и т.д. 
При этом можно использовать практически все диало- 
говые возможности Рагабох, расширяя их средствами 
реакции на нестандартные клавиши или заменяя 
стандартные действия Рагабох на необходимые в кон- 
кретной программе. 

Набор встроенных функций РАЬ достаточно полон 
и включает в себя: 

- функции работы с датой и временем; 

- функции финансовых вычислений; 

- функции получения сведений об объектах базы дан- 
ных и программы, о рабочей области и параметрах 
системы; 

- функции ввода-вывода; 

- математические функции; 

- статистические функции; 

- функции работы со строками. 

Система программирования содержит интерпрета- 
тор, редактор и отладчик. Для повышения производи- 
тельности труда разработчика приложений в Рагабох 
реализован мощный генератор приложений РРго&, по- 
зволяющий существенно сократить время на проведе- 
ние рутинных операций обработки данных в новых 
прикладных задачах. Кроме того, РРго? сам по себе 
может служить неплохим самоучителем работе с РАЬ. 

При использовании в локальной сети Рагабох обес- 
печивает автоматическую блокировку, разблокирова- 
ние и запрещение блокирования своих объектов в за- 
висимости от типа операции их обработки. Все эти 
функции осуществляются автоматически ядром си- 
стемы. При разработке сетевого приложения, напри- 
мер, на Сііррег, функциональные режимы, которые 
Рагабох выполняет самостоятельно, необходимо про- 
граммировать вручную. 


Документация и система “помощи** 

Документация Рагабох подробна, хорошо организо- 
вана, содержит большое количество примеров. Ее удо- 
бно использовать и при начальном знакомстве с си- 
стемой, и при получении справок в ходе работы. К 
сожалению, все это нельзя отнести к системе помощи. 
Несмотря на большой объем сведений и контекстную 
чувствительность, она обладает весьма серьезными не- 
достатками: 

- пауза при вызове Неір заметна даже на машинах 
типа АТ; 

- индекс помощи практически не структурирован, по- 
иск по нему затруднен; 

- практически отсутствуют ссылки на близкие по 
смыслу или связанные понятия. 

Кроме того, раздел со сведениями о командах и 
функциях языка, пожалуй, наименее полон и вклю- 
чает только название команды или функции и ее 
формат — без каких-либо комментариев. Хорошо, что 
этот недостаток ощущается преимущественно про- 
граммистами-профессионалами, а не конечными поль- 
зователями. 

Структуры данных 

Рагабох — “истинно** реляционная СУБД, что вы- 
годно отличает его от семейства 6ВА5Е (Сііррег, 
РохВазе и РохРго, бВХЬ и проч.). Действительно, 
табличная форма хранения данных часто приводит к 
тому, что программные средства семейства 6ВА5Е 
ошибочно относят к классу реляционных СУБД. .В то 
же время, в них отсутствует главная отличительная 
черта реляционных систем, языковые средства мани- 
пулирования данными, — реляционная алгебра или 
средства реляционного исчисления. Наш опыт показы- 
вает, что программы из семейства 6ВА5Е правильнее 
было бы отнести к классу СУБД с плоскими файлами, 
а по некоторым признакам они вообще ближе к си- 
стемам файлового доступа, а не к СУБД. 

Реляционность Рагабох, заключающаяся в мощном, 
реляционно-полном языке манипулирования дан- 
ными, — несомненное достоинство, обеспечивающее 
превосходство над семейством 6ВА5Е. В то же время, 
за счет великолепных технологических решений Рага- 
бох в основном лишен главного недостатка, традици- 
онно связываемого с реляционными системами, невы- 
сокой производительности. По скорости выполнения 
поисковых операций он заметно опережает и Сііррег, 
и РохЬазе — чемпионов семейства 6ВА5Е. 

Сама по себе реляционная модель не лишена недо- 
статков. Основной из них — неудобство отображения 
семантики предметной области средствами описания 
схемы базы данных. Так, например, в Рагабох суще- 
ствует понятие семейства файлов, ассоциированных с 
таблицей-отношением — экранные формы, отчеты, 
индексы и т.п. Многие операции работы с таблицей 
(реструктуризация, копирование, удаление) автомати- 
чески производят адекватные изменения с членами 
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семейства. Вызывает сожаление отсутствие таких воз- 
можностей для совокупности таблиц, входящих в не- 
которую базу данных. Структура многотабличной базы 
данных (а именно в ней в значительной мере сосредо- 
точено семантическое описание предметной области) в 
Рагабох не фиксируется. Связи между таблицами, 
ограничения целостности задаются в описаниях эк- 
ранных форм и отчетов и в значительной степени в 
программном коде приложения, поддерживающего 
базу данных. 

Такой способ представления семантики, очевидно, 
далек от идеала: средства моделирования данных ком- 
мерческих реляционных систем (в том числе и Рага- 
бох), ориентированы на описание таблиц, а не объек- 
тов реального мира, их свойств и взаимосвязей. 

Справедливости ради следует отметить, что члены 
семейства 6ВА5Е вообще “не доросли** до того, чтобы 
их критиковать с точки зрения большей или меньшей 
семантичности моделей данных. 

К недостаткам реляционной структуры данных 
Рагабох можно отнести также отсутствие аналога тек- 
стовых полей данных с переменной длиной и возмож- 
ность использования только единственного (хотя и со- 
ставного) ключа таблицы для связи ее с другими таб- 
лицами. 

Разработка приложений — 
шаг навстречу пользователю 

Высокая эффективность Рагабох как средства 
управления данными приводит к мысли о возможности 
его использования в составе больших разнородных си- 
стем обработки информации, где СУБД, как правило, 
является одной из главных компонент. За последние 
полтора года коллектив, к которому принадлежат ав- 
торы, выполнил следующие разработки: 

- создание оболочки экспертной системы, включающей 
Рагабох в качестве системы хранения и обработки 
данных; 

- стыковка Рагабох с системой обработки графических 
данных и большой программой численного анализа, 
реализованной на Рогігап; 

- разработка прикладной информационной системы на 
основе баз данных общим объемом более 17 тысяч 
строк исходного текста на РАЬ. 

Во всех этих случаях приходилось решать проблемы 
взаимодействия Рагабох с другими программами и па- 
кетами программ, оптимизировать критические по 
времени исполнения участки РАЬ-программ, доби- 
ваться эффективного использования памяти. 

В Рагабох реализована возможность запуска про- 
грамм операционной системы командами Кип и Кип- 
Вів. Нетрудно догадаться, что выполнение первой из 
них оставляет для запускаемой программы не так уж 
много свободной памяти, а выполнение второй требует 
заметного времени. 

Передача параметров внешней программе возможна 
либо через командную строку запуска, формируемую в 
Рагабох, либо через файл. Возврат значений — только 


через файл, а средства Рагабох для работы с вне- 
шними файлами 008, на наш взгляд, развиты недо- 
статочно. 

Кроме того, существует целый ряд тщательно огова- 
риваемых в документации запретов на действия, осу- 
ществляемые внешней программой. 

Таким образом, возможности связи приложений, 
реализованных на Рагабох, с миром внешних, напи- 
санных не на РАЬ, программ, оставляют желать луч- 
шего. Удачным исключением можно считать, пожа- 
луй, простую и удобную систему экспорта/импорта 
данных. 

Для обеспечения эффективного использования па- 
мяти при разработке программ на РАЬ следует: 

- тщательно проектировать модульную структуру про- 
граммы; 

- своевременно применять в тексте программы опера- 
торы освобождения памяти, занимаемой перемен- 
ными и процедурами (Кеіеазе); 

- избегать рекурсивных вызовов процедур; 

- своевременно закрывать файлы базы данных. 

При соблюдении этих несложных правил можно со- 
здавать приложения практически неограниченного 
размера. В то же время, если пренебречь этими требо- 
ваниями, неработоспособной может стать сравни- 
тельно небольшая программа. Несмотря на это, опыт 
показывает, что управление памятью в больших про- 
граммах на РАЬ может быть осуществлено значи- 
тельно эффективнее, чем, например, в СНррег 8ит- 
тег'87 или СНррег 5.0. 

В целом, система программирования РАЬ — это си- 
стема интерпретирующего типа, поэтому, несмотря на 
исключительно быструю работу с базой данных, неко- 
торые программы общего назначения в Рагабох могут 
работать сравнительно медленно. Действительно, про- 
изводительность предварительно откомпилированных 
программ, например, в задачах математических расче- 
тов заметно выше. Простой пример — расчет суммы 
квадратов чисел от 1 до 10000. Тест проводился на 
машине типа РС АТ с тактовой частотой ІОМгц. 

Пакет ТигЬо С++ СНррег 6ВА5Е 111+ РАЬ 

Время 

(сек.) 3.242 19.000 256.000 69.000 

В то же время, нельзя не отметить практически че- 
тырехкратное преимущество Рагабох по отношению к 
другому интерпретатору — 6ВА5Е III Ріиз. 

А если нужно еще быстрее? 

Большие надежды разработчиков приложений Рага- 
бох связаны с новым продуктом фирмы Вогіапб, Рага- 
бох Еп^'іпе, который представляет собой библиотеку 
функций для работы с базами данных Рагабох. С ее 
помощью можно выполнить из программы, написан- 
ной на языках С или Разсаі, большинство операций по 
созданию и ведению баз данных, провести поиск в 
таблицах, разработать сетевые приложения, использу- 
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ющие богатые средства Рагабох для коллективного до- 
ступа к базам данных. К сожалению, в текущей вер- 
сии Рагабох Еп^іпе нельзя непосредственно из про- 
граммы на языке высокого уровня использовать такие 
“изюминки" Рагасіох, как экранные формы, запросы и 
отчеты. 

Разработчики фирмы Вогіапсі в рамках Рагасіох Еп- 
8Іпе 2.0 реализовали не только возможность работы с 
файлами Рагасіох из языка ТигЬо Разсаі, но и про- 
граммный интерфейс к ЛІХ (динамически компону- 
емым библиотекам) МісгозоГі АУіпбо^ѵз 3.0. В резуль- 
тате программисты всего мира получили' уникальный 
набор инструментальных средств для работы с базами 
данных, до сих пор отсутствовавший в среде МЗ-Э05. 

Диалог должен быть современным! 

Набор команд РАЦ используемых для организации 
диалога с пользователем, существенно превосходит 
возможности б В АЗЕ, но уступает аналогичным сред- 
ствам такой системы программирования, как Сііррег. 
Реализация меню в Рагасіох осуществляется в так на- 
зываемом Ьоіиз-подобном стиле (горизонтальное раз- 
ворачивающееся меню со строкой-комментарием). В 
то же время, с помощью РАЬ и процедур из поставля- 
емого с Рагасіох набора ТооІКИ (полезные примеры 
программ на РАЬ) можно запрограммировать и более 
удобные всплывающие меню. 

В языке программирования РАЦ к сожалению, 
отсутствует понятие окна и средств для работы с 
окнами. Вместо этого введено понятие занавеса, эк- 
ранной поверхности, на которой Рагасіох производит 
свои действия. Эта поверхность может быть закрыта 
занавесом (возможно, прозрачным), на котором ото- 
бражается экранный вывод РАЬ-программы. При про- 
граммировании это не всегда удобно, да и выглядит 


как-то несовременно. Не поддерживается интерфейс с 
мышью. Оставляет желать лучшего и управление зву- 
ком. 

Команды ввода-вывода на экран не позволяют со- 
хранять, очищать или закрашивать область экрана 
(занавеса). Ввод данных в базу удобно реализуется в 
виде экранных форм, а вот средства для запроса ка- 
ких-либо параметров, не являющихся полями базы 
данных, недостаточны. Нельзя, например, менять 
форму' и цвет курсора. В целом, все, что касается про- 
граммно управляемых средства диалога, оставляет ши- 
рокое поле для совершенствований. 

Следует отметить, что в ближайших версиях и сам 
Рагасіох, а не только Рагасіох Епвіпе, будет работать в 
среде АУіпсіогѵз. Первые шаги в этом направлении сде- 
ланы в версии 3.5. В ее дистрибутив входят .РІР 
файлы и иконки \Ѵіпсіоѵѵ5 для Рагасіох и его генера- 
тора приложений РРгоі. На рубеже 1992 года ожида- 
ется и появление специализированной версии Рагасіох 
для ^іпбосѵз. 

В заключение следует отметить, что предъявление 
программистами таких требований к Рагасіох, который 
является проблемно-ориентированной программой для 
ведения баз данных (СУБД), свидетельствует, в пер- 
вую очередь, о его огромном потенциале в качестве 
средства создания автоматизированных рабочих мест 
различного назначения. Действительно, вряд ли кто- 
нибудь будет ожидать многого от программной си- 
стемы, которая не удовлетворяет пользовательским 
требованиям сама по себе. В то же время, мощную, 
гибкую и удобную для разработчиков прикладных про- 
грамм систему всегда хочется улучшить одной-двумя 
ценными характеристиками. 

Д.Хан-Магометов, 
К.Раннев, А.Зотоѳ 


2спі1Н Эаіа Зузіетз демон- 
стрировал на выставке Сотбех в 
Лас-Вегасе новый компьютер- 
блокнот (поіеЬоок) МазіегзРогі 
3863Ье. 208 выпустила также 
настольный компьютер на про- 
цессоре 4868Х. 

МазіегзРогі 3868Ье выполнен 
на новом 25-мегагерцовом про- 
цессоре І803865Ц который рабо- 
. тает на 25 процентов быстрее, 
чем ранее имевшийся 3868Х. 
Компьютер имеет 85-мегабайт- 
ный жесткий диск, улучшенный 
параллельный порт, дисплей 
ѴСА, и 2 Мбайта ОЗУ. Машина 


весит 7 фунтов (3.15 кг) и нач- 
нет продаваться в США в ноябре 
за 5,000 долларов. 

Примененный в рабочей стан- 
ции 2-4868Х/25Е процессор 
804868Х имеет производитель- 
ность на уровне 4860Х, работа- 
ющего с такой же тактовой час- 
тотой. Разница состоит в том, 
что в нем не встроен модуль вы- 
числений с плавающей точкой. 

Компьютер имеет графичес- 
кий адаптер 2-649 Техаз Іпзіги- 
тепіз СгарЬісз АгсЬИесіиге 
(сокращенно — Т1СА), обеспе- 
чивающий разрешающую спо- 


собность 1024x768 пикселей и до 
256 цветов. 

2-4868Х/25Е с винчестером 
емкостью 200 Мбайт называется 
Мобеі 200 (6199 долларов), а без 
винчестера и видеоадаптера — 
Мобеі 1 (4049 долларов). Обе 

машины имеют 4 Мбайта ОЗУ с 
возможностью расширения до 
32 Мбайт на основной плате, 
три слота Е13А (Ехіепбеб 
Іпбизігу Зіапбагб АгсНііесіиге), и 
поддержку математического со- 
процессора \Ѵеііек 4167 . 

ЫетЬуІез Ые\ѵз Иеѣѵогк, 
28 ОсіоЬег 1991 
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^кассовое освоение пользователями 
техники персональных вычислений 
быстрыми темпами формирует 
потребности совместного 
использования информации. Эта 
тенденция ведет к созданию баз данных 
коллективного пользования, в которых 
центральным технологическим звеном 
становятся серверы баз данных. 


Серверы баз данных 


Введение 

Программные средства серверов баз данных обес- 
печивают реализацию многопользовательских прило- 
жений, централизованное хранение, целостность и 
безопасность данных. Производительность серверов 
баз данных на порядок выше по сравнению с тради- 
ционными файл-серверами, которые используются в 
локальных сетях. Кроме того, 5(}Ь-серверы баз данных 
для ПЭВМ обеспечивают многие возможности боль- 
ших и мини-ЭВМ по ценам значительно более низ- 
ким, соответствующим ценам ПЭВМ. 

Данный обзор посвящен анализу основных проблем 
в развитии технологии серверов баз данных, а также 
рассмотрению возможностей некоторых зарубежных 
программных средств, реализующих новую техно- 
логию. 

Прежде чем перейти к такому анализу, хотелось бы 
более подробно рассмотреть основные принципы 
работы и отличия серверов баз данных от тра- 
диционных файл-серверов. 

Локальные вычислительные сети (ЛВС), первона- 
чально созданные для совместного использования до- 
рогостоящего периферийного оборудования, эволюцио- 
нировали со временем до такой степени, что стал воз- 
можен доступ многих пользователей к одним и тем же 


файлам, и для многих персональных систем управле- 
ния базами данных были предложены сетевые версии. 
Однако скоро стало ясно, что сетевые СУБД, основан- 
ные на модели файл-сервера, недостаточно мощны для 
мини-ЭВМ. Но, почему? Ответ на этот вопрос — ос- 
нова для понимания принципов работы серверов баз 
данных. 

Файл-серверу на микропроцессоре 386 с тактовой 
- частотой 25 МГц и объемом памяти жесткого диска 40 
Мб трудно соперничать с мини-ЭВМ. Конечно, можно 
использовать устройства оптической памяти, чтобы 
имитировать огромную память миникомпьютера. Но в 
нагруженной сети неизбежно встанет проблема произ- 
водительности, а также безопасности и целостности 
данных. 

Производительность является проблемой не потому, 
что современным 386 процессорам не хватает требуе- 
мой мощности, а потому, что сегодняшние файл-сер- 
веры используют принцип “все или ничего" для ис- 
полнения запросов рабочих станций. Полные копии 
файлов базы данных постоянно перемещаются вперед- 
назад по сети. Проблемы с безопасностью и целостно- 
стью данных возникают из-за того, что файл-серверы 
изначально не были сконструированы с учетом целост- 
ности данных и их восстановления в случае аварии, 
неявного распараллеливания задач (ішріісіі сопсиг- 
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гепсу) и централизованного контроля управления дан- 
ными, типичными функциями, выполняемыми СУБД 
на средних и больших ЭВМ. 

Архитектура “клиент-сервер“ (С8А — Сііепі Зегѵег 
АгсНИесіиге) заменила модель “файл-сервера** на бо- 
лее мощную, состоящую из “клиентов** и “серверов**, 
что позволило совместить достоинства однопользова- 
тельских (высокий уровень диалоговой поддержки, 
дружественный интерфейс и низкую цену) и более 
крупных компьютерных систем (поддержка целостнос- 
ти и защита данных, многозадачность). 

В классическом понимании СУБД представляет со- 
бой набор программ, позволяющий создавать и под- 
держивать базу данных. С функциональной же точки 
зрения СУБД выглядит иначе. 

Функционально СУБД состоит из трех частей: ядра 
базы данных (еп^іпе), языка (Іап^иа^с) и инструмен- 
тальных средств программирования (іооіз). Инстру- 
ментальные средства относятся к интерфейсу пользо- 
вателя, или внешнему интерфейсу, который мы ис- 
пользуем. Они могут включать процессор обработки 
запросов на языке 3(21. или (2ВЕ ((^исгу Ьу Ехатріе 
— язык запросов по образцу). Язык — это совокуп- 
ность процедурных и непроцедурных команд, поддер- 
живаемых СУБД. Ядро базы данных выполняет все ос- 
тальные функции, которые обычно включаются в по- 
нятие “обработка базы данных**. Термины “ядро** (еп- 
2 'те), “сервер** (зегѵег) и “внутренний интерфейс** 
(Ьаск епб) являются синонимами. Основная идея мо- 
дели “клиент-сервер** заключается в том, чтобы распо- 
лагать серверы на мощных машинах, а приложениям, 
использующим языковые компоненты СУБД, обеспе- 
чить доступ к ним с менее мощных машин-клиентов 
посредством внешних интерфейсов. Тем самым ис- 
пользование серверов базы данных позволяет задейст- 
вовать ресурсы как самого сервера базы данных, так и 
клиентов, менее мощных компьютеров. Обособляя опе- 
рации работы с базой данных, архитектура “клиент- 
сервер** позволяет объединить усилия всех компонен- 
тов системы. Сервер базы данных или внутренний ин- 
терфейс (Ьаск-епб) обслуживает базу я отвечает за- 
дел остность и сохранность данных, а также обеспечи- 
вает операции ввода/вывода при доступе клиента к 
информации. 

Ввод/вывод в базе данных основан не на физичес- 
ком дроблении данных, а на логическом. Это означа- 
ет, что вместо того, чтобы отправлять клиентам пол- 
ные копии файлов базы данных, сервер посылает им 
только логически необходимые порции, уменьшая тем 
самым трафик сети. 

Вообще говоря, серверы баз данных совсем не обя- 
зательно используют язык 3(21.. Но большинство сер- 
веров, разрабатываемых сегодня, делает это, т.к. 8(21. 
очень удобен как язык для описания логических под- 
множеств базы данных. 

В архитектуре “клиент-сервер** интерфейс пользо- 
вателя, отображения и запросы хранятся отдельно от 
системы управления реальными данными и их фильт- 
ров. Внешние прикладные программы сориентированы 


более на представление информации клиенту. Сервер 
же обрабатывает запросы прикладных программ, вы- 
бирает необходимые данные, посылает их клиентам по 
сети и производит обновление информации. 

Серверы баз данных расширяют диапазон программ 
пользователей, которым доступны данные в СУБД. 
Это происходит за счет централизованного хранения 
данных (в отличие от файл-серверов, поддерживаю- 
щих отдельные файлы для каждого типа 
приложений). Обращаться к данным могут не только 
специально написанные прикладные программы базы 
данных, но и электронные таблицы, настольные 
издательства или текстовые процессоры. Сервер базы 
данных обеспечивает интеграцию данных независимо 
от использующих их приложений. Данные в СУБД 
всегда поддерживаются в актуальном состоянии и 
могут быть использованы совместно многими поль- 
зователями. Централизованное хранение и програм- 
мные средства сервера базы данных обеспечивают вы- 
полнение таких важных функций СУБД, как диалого- 
вое управление и восстановление целостности храни- 
мой информации после сбоя. 

Все перечисленные выше функции серверов баз 
данных будут более подробно рассмотрены в следую- 
щих разделах. 

Тенденции развития рынка 

Рынок программных средств серверов баз данных в 
настоящее время весьма активно развивается и делит- 
ся на две части. Одна из них — это крайне необходи- 
мые приложения, позволяющие пользователям и раз- 
работчикам на основе ПЭВМ и серверов баз данных 
создавать системы, для которых ранее использовались 
универсальные или мини-ЭВМ. Это рынок, где разви- 
вались и впредь будут развиваться административные 
информационные системы, выполненные на Си, 
Коболе или программных средствах четвертого 
поколения (3(21. ЛѴіп<1олѵз или бВазе). В таких 
системах для разработчиков и пользователей очень 
важны возможности создания надежных программ и 
обеспечения их работоспособности в многополь- 
зовательском режиме в локальных сетях ПЭВМ. 

Другая часть рынка программных средств серверов 
баз данных — это приложения для создания структур 
автоматизации типа “групповое обеспечение/офис“ 
(вгоирѵаге/оПісе). Это системы, в которых ядро мно- 
гопользовательской базы данных используется для ав- 
томатизации работы офиса, будь то электронная почта 
или электронные таблицы, связанные с базами данных 
(пакеты Ьоіиз 1-2-3, Ехсеі). 

В настоящее время на рынке зарубежных ПС серве- 
ров баз данных имеется около десяти основных про- 
дуктов [2]. Сравнительные характеристики этих про- 
дуктов приведены в таблице. Среди наиболее популяр- 
ных программных продуктов можно назвать 3()Ь 
Зегѵег (МісгозоН), 5(21. Вазе Зегѵег (Сиріа 
ТесНпоІозу), Огасіе Зегѵег (Огасіе Согр.). 
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Таблица сравнительных характеристик серверов 



1 

1 

Возможности ядра базы данных 







Продукт/Версия/ 

| Объем 

I Объем | 

Макс. 

нисло 

1 

Макс. 

длина 








Іопера- 

| внеш- 1 



I- 

— 








Компания 

ІТИВНОЙ 

I ней | 

открыт- | 

полей 

|текс-гс 

|числово| 



Типы 

полей 


| памяти 
1 

| памяти | 

аіх ОКОНІ 

записи | 

і 

поля 

| го поля| 








1 

| 1 

2 

3 

4 

і 

5 

6 





1 


Етргезз Я0ВМ5 4 

| 1 МБ 

| 15 МБ | 

НО 1 

9999 

1 


1 15 | 

і, 

с, 

Р. 

0, 

м, 

Ві. Ц 

Етргезз ЗоіЧѵѵаге 


1 1 
1 1 

1 

1 




1 1 
1 1 







ИеТМаге 301. 2.10 

| 1 МБ 

| 5.4 МБ | 

255 1 

НО 

1 

255 

1 1 

1 15 | 

і, 

с. 

1, 

Р. 

0. 

м 

Иоѵеіі 

і 

1 

і і 

1 1 

1 

1 


1 

1 


і і 

1 1 







Огасіе Зегѵег 1.С 

| 8 МБ 

| 20 МБ | 

НО 1 

254 

1 

64 

і і 

1 38 | 

і. 

с. 

N. 

0 



Огасіе 

1 

1 

1 1 
1 1 

1 

1 


1 

1 


1 1 
1 1 







301 Зегѵег 1.1 

| 8 МБ 

| 14 МБ | 

10.000 | 

255 

1 

1 

НО 

1 1 
1 15 | 

і, 

с. 

Р, 

Р. 

1, 

0, М, Ві, ц 

МісгозоТТ 

і 

і 

1 1 
1 1 

1 

1 


1 

1 


1 1 
1 1 







501. Зегѵег 4.0 

| 6-8 МБ 

| 30 МБ 1 

НО 1 

250 

1 

1 

255 

1 1 
1 но | 

і. 

с, 

Р, 

1. 

0, 

и 

ЗуЬазе 

1 

1 

і і 

1 1 

1 

1 


1 

1 


1 1 
1 1 







ЗОІВазе 4.0.1 

| 4 МБ 

| 1 МБ | 

Нй 1 

254 

1 

1 

НО 

1 1 
1 22 | 

і, 

с, 

Р. 

0, 

Р, 

0, Ві 

Оиріа 

і 

і і 

1 


1 


і і 







Тесбпоіодіез 

і 

1 

і і 

1 1 

1 

1 


1 

1 


і і 

1 1 







ѴІА/ОЯЕ 1.2.3, 

| 640 КБ 

| 4.5 МБ | 

НО 1 

НО 

1 

1 

НО 

1 1 
1 16 | 

і. 

с. 

Р, 

и 

0. 

Ві 

ѴІА ІпТогтаііоп 

1 


1 


1 


і і 







Зузіетз 

1 

1 

і і 

1 і 

1 

1 


1 

1 


і і 

1 1 







ХйВ 2.30 

| 640 КБ 

| 3.5 МБ | 

246 | 

400 

1 

1 

4056 

1 1 
1 15 | 

і, 

с, 

N. 


Ві 


Х0В Зузіетз 

1 

і і 

і 


1 


і і 








НО - в зависимости от типа компьютера 

В графе 7 приняты следующие сокращения типов полей: 


I (Іпіедег) - целое; 

С (СИагасТег) - символ; 

Р (Ріоаі) - число с плавающей 
точкой; 


Р (РаскесІ) - упакованный 
формат; 

I (1.одіса() - логический; 
Э (йате) - дата; 


М (Мето) - текстовое поле; 

Ві (ВіоЬ) - двоичный формат; 

Ц (Іізег ОеТіпеб) - определяемый 
пользователем. 
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Таблица сравнительных характеристик серверов (продолжение) 



Продукт/Версия/ 

Компания 


| Кол-во правил | 

Реляционные 

1 

Реализация 

1 


1 Кодда , поддер- 1 

ВОЗМОЖНОСТИ 

1 

интерфейса 

1 

Язык 

Іживаемых СУБД | 


1 

3-го покол. 

1 


1 1 


1 

(3 ЗОБ) 

1 


1 8 | 
1 I 

9 

1 

I 

10 

1 

1 

11 


программирования 


I 


Ешргезз Я0ВМ5 4 
Ешргезз ЗобТмаге | 

12 

| V РК РК N0 | 
1 М ВІ 1 

В 

1 с 


ЫеТѴУаге ЗОБ 2.10 | 

№ѵе1і 

7 

| V ОД N0 | 

1 1 

1 1 

В 

і 

| СоЬоІ, С, АззетЫег Вазіс, Разсаі 

Огасіе Зегѵег 1.0 | 

Огасіе | 

1 

10 

| V Зп йо РК 1 

| РК 03 N0 М I 

■ 

В 

і 

| Рогбгап, СоЬоІ, С 

1 

1 


ЗОБ Зегѵег 1.1 
МісгозоРІ: 

10 

| V 5п йо РК N01 
1 МѴ ВІ РК 03 | 

С 

| С, СоЬоІ , Вазіс 

1 

1 


501 Зегѵег 4.0 
ЗуЬазе | 

10 

| V 0о РК РК 03 | 
1 N0 МѴ ВІ 

С 

1 

1 с 

1 

1 


ЗОЬВазе 4.0.1 
биріа ТесЬпоІодіез | 

10 

| V Зп РК 03 N01 
1 NV 

В 

1 

| Рогбгап, СоЬоІ, С АззетЫег, 

1 

1 

Вазіс 

1 

ѴІАДШЕ 1.2.3, ѴІА | 
ІпбогшаТіоп ЗузТешзІ 

8 

1 

| РК РК N0 NV 1 

1 1 

1 1 

В 

| С, СоЬоІ, ѴІА 

1 

1 


Х0В 2.30 
Х0В Зузіетз 

12- 

1 

| V Зп 0о РК РК| 
1 ВІ 03 N0 NV 1 

В 

ІРогТгап, СоЬоІ, С, АззетЫег, 
1 

Разсаі 


1. В графе 9 приняты следующие 
сокращения : 

V (Ѵіемз) - представления 
пользователя; 

5п (ЗпарзЬоІз) - выборки; 

О (Оошаіпз) - домены (области 
определения столбцов 
отношений); 


РК (Ргішагу Кеуз) - первичные 
ключи; 

N0 ( МезТесІ Оиегіез) - 
рекурсивные запросы; 

М (ИиИ Ѵаіиез) - 
неопределенные величины; 

ВІ (ВебегепЫаі ІЫедгіТу) - 
целостность ссылок. 


2. В графе 10 приняты следующие 
сокращения : 

Е (ЕшбеООеО 301.) - встроенный 

зон 

С (Саіі ІЫгегРасе) - интерфейс 
вызова; 

В (ВоТЬ) - обе возможности. 
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Таблица сравнительных характеристик серверов (продолжение) 


Продукт/Версия/ | 
Компания 

Внешний интерфейс 

Сетевая поддержка 


поддерживаемый данным 
сервером БД 

сетевые операци- 
онные системы 

| сетевые 
| прото- 
| колы 

1 

12 

13 

14 

Ешргезз РШВМЗ 4 | 

Ешргезз 401, Ешргезз 

ЭЕС АЯ ЫРЗ ЯР5 

1 ТСР/ІР 

Ешргезз ЗоТТѵѵаге | 

Яерогр МгіРег, ІпРег- 


1 


асРіѵе ЗОЕ 


1 

МеРМаге 501 2.10 

501 Рііе, ЯаЗОІ, Х0І., 

N N386 

| ІРХ/5РХ 

Моѵе 1 1 

ХРгіеѵе Р 1 из , Я&Я, 


1 


Оиіск.зііѵег, ЙВХІ., 


1 


АІрРа 4, 1_оРиз 


1 

Огасіе Зегѵег 1.0 | 

Рго*С, 301_*Рогтз, 

N N386 І.М 1.5 В 

| ТСР/ІР, N311)6(1 Рірез 

Огасіе | 

801.*ЯерогРигіРег, 

0ЕС АЗ 

1 Ме-СВІ08 


801.*Мепи,501-*Р1и5, 


1 


Огасіе, Оиіскзі Іѵег/ 


1 


йВХІ_ Рог Огасіе, 


1 


ЗУАСС, ЗАМ, оРРегз 


1 

506 Зегѵег 1 . 1 

ОаРаЕазе, Рагайох 3.5, 

N N386 ІМ 65 NР 

| ТСР/ІР, Машей Рірез 

МісгозоРР | 

Айѵапсей ЯеѵеіаРіоп, 

0ЕС 

1 


шсІЬз 0ЬіесР/1, ѴіпгапР 


1 


ВА8ІС, ОаРаѵѵіг 0В50Е, 


1 


оРРегз 


1 

501 Зегѵег 4.0 

І-оРиз 123, МісгозоРР 

N N386 ІМ 15 ЭЕС 

| Машей Рірез 

ЗуЬазе | 

Ехсеі, АРТ МогкЬепсР, 


1 


ЗУАСС, ЗАМ 


1 

801-Вазе 4.0.1 

301-Міпйоѵѵз, 2ІМ, ЙВХЬ, 

N N386 І-М 1.5 В 5 

| ТСР/ІР, Машей Рірез 

СирРа ТесРпоІодіезІ 

Оиіскзі Іѵег, Сі іррег. 

35 3+ М3 

1 МеРВІОЗ 


ЗАМ/ОВі , М0МА0, 801. 


1 


Сошшапсіег, 801. 


1 

ѴІА/0ЯЕ 1.2.3, VI А 1 

ѴІА/С001, ЫРб/Я. ХІ+, 

N N386 І.М 1.5 В 

| ТСР/ІР, Машей Рірез, 

ІпРогшаРіоп 5узРетз| 

Сазеѵюгкз-РМ.С 

МР Т 

1 Меі ВТ 05 


Іапдиаде Рооіз 



ХйВ 2.30 

Я&Я Яерогр МгіРег, 

N N386 NР 

1 Меі В 105, ІРХ/5Х 

ХОВ ЗузРетз 

ЗОЯ, ЗАМ, Х0В-501-, 


1 


РгееРогш.ХОВ-ОгарР 


1 


N - №6 Маге; 

N386 - Не* Маге 386; 
ытв - МеР ВІОЗ; 

І-М - ІАМ Мападег; 

1.3 - ІВМ Ш Зегѵег; 


В графе 13 приняты следующие сокращения : 


В - Вапуап; 

ЭЕС - ОЕСЫеі:; 

35 - ЗЗбаге; 

3+ - 3 РІ и$ Ореп; 
51 - ЗбагШ; 

АЗ - Арріезбаге; 


АТ - Арріе Та I к; 

Т - Т0Р5; 

АЯ - Аро I Іо Віпд; 

NРЗ - МеРМогк Рііе ЗузРеш; 
М3 - МЗ-МеР. 
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По мнению зарубежных экспертов [3] 5(}Ь-серверы 
баз данных являются новейшим и потенциально са- 
мым мощным приложением для сетевой обработки 
данных. На сегодня рынок программных продуктов 
серверов баз данных не очень велик, но по прогноз- 
ным оценкам специалистов в ближайшие пять лет 
количество реализованных пакетов может возрасти в 
45 раз, а прибыли от их реализации — более чем в 
100 раз. 

Операционная среда сервера 

Под операционной средой сервера базы данных мы 
понимаем возможности операционных систем компью- 
теров и сетевых ОС. Каждый сервер базы данных мо- 
жет работать на определенных типах компьютеров и 
сетей (все типы сетевых ОС и протоколов, поддержи- 
ваемых конкретным сервером базы данных, приведены 
в таблице сравнительных характеристик серверов. 
Операционными системами серверов могут быть 005, 
03/2, Хепіх, ІІпіх а также 1>ЕС ѴМ5. Рабочие 
станции пользователей обычно работают под управле- 
нием 008, 08/2, Хепіх или ІІпіх. Существуют также 
возможности смешанного использования различных 
операционных систем. Выбор наиболее подходящей 
операционной системы необходимо делать с учетом 
многих факторов, включая стандарты, используемые в 
организации, предполагаемые объемы данных и вы- 
числений, принимая во внимание перспективы совер- 
шенствования и расширения системы. 

Выбор локальной вычислительной сети для сервера 
базы данных производится также по комплексным 
критериям. Серверы баз данных ЗріЛазе (Сиріа 
ТесЬпоІОбу), ХОВ (ЗоІІѵѵаге ХОВ ЭВМЗ) и ѴІА/ОКЕ 
(Іпіогтаііоп Зузіетз) работают под управлением 005 
и 03/2 и поддерживают сетевой протокол ЫеіВІОЗ. 
Сервер ХОВ работает кроме того под управлением не- 
которых типов ОС ІІпіх. При установке на сервере 
операционной системы ІВМ 05/2 Ехіепсіеб ЕгіИіоп ра- 
бочие станции клиентов могут использовать как 005, 
так и 08/2. Эта ОС интегрируется с сетевым серве- 
ром фирмы ІВМ и использует протокол 05/2 Ехіеп- 
беб ЕсШіоп Соштипісаііоп Мапаяег. Сервер ЗС^Ь Зегѵег 
(МісгозоІІ/ЗуЬазе) требует 03 /2 для сервера и под- 
держивает рабочие станции клиентов на базе 008 и 
08/2. Ему требуется поддержка №те<1 Рірез и других 
сетевых функций управления прикладного програм- 
много интерфейса (ІЛЫ Мапа^ег АРІ). Поскольку 8(}Ь 
Зегѵег является одновременно и продуктом фирмы 5у- 
Ьазе, его пользователи могут переходить к ІІпіх или 
ѴМ8, которые фирма ЗуЬазе поддерживает без изме- 
нения прикладных кодов. 

Сервер Ыеілѵаге 5(ЗЬ, (Ыоѵеіі) работает как ѴАР 
(Ѵаіие Асісіесі Ргосезз), под управлением ІЧоѵеІІ ІЧеі- 
АѴаге или ЫЬР (Ыейѵогк ЬоабаЫе Мосіиіе — сетевой 
загрузочный модуль), в сети ИеЛѴаге 386 и использует 
систему управления транзакциями ТТ5 (Тгапзасііоп 
Тгаскіпв Зузіет). 


Сервер базы данных фирмы Огасіе (Огасіе Зегѵег) 
поддерживает ЫЕТВІОЗ, ІР5/5РХ и Вапуап Ѵіпез. 

В целом, при разработке систем прежде всего необ- 
ходимо оценить будущие прикладные задачи системы, 
а затем искать оптимальную операционную систему и 
сетевую конфигурацию. 

Использование языка 8(2Ь 

Большинство серверов баз данных поддерживает 
полный набор команд языка ЗОБ, который соответ- 
ствует либо стандарту АЫЗІ, либо стандарту ІВМ. Кро- 
ме того, они обычно включают определенные расши- 
рения стандарта 5(2Ь. Например, сервер ХОВ сов- 
местим с 5(}Ё СУБД 0В2 фирмы ІВМ. Сервер ХОВ 
очень близко подходит к архитектуре вложенного язы- 
ка 5(2Б фирмы ІВМ. 

Ряд программных продуктов поддерживают специ- 
альные типы данных и функций. ЗІ^Ь-продукты, реа- 
лизующие ядро СУБД в Іп^гез, Ешргезз иДпіегЬазе, 
позволяют разработчикам определять собственные 
функции, используемые вместе с 8(}Ь-командами по- 
добно любым другим 5(}Ь-функциям. Интеллектуаль- 
ная база данных Іп^гез (версия 6.3) имеет средства, 
позволяющие определять новые типы данных и опера- 
торов. СУБД ХОВ и Огасіе обрабатывают рекурсивные 
запросы. 

Большая часть 8<ЗЬ-серверов (ядро) может хранить 
описания базы данных в системном каталоге. Этот ка- 
талог обычно бывает доступен пользователю — для об- 
ращения к нему используются те же 8(}Ь-запросы. 
Информация, хранящаяся в каталоге имеет чрезвы- 
чайно важное значение. Обычно там хранятся описа- 
ния таблиц, колонок, индексов колонок и имена физи- 
ческих файлов. Некоторые каталоги хранят статисти- 
ческую информацию о таблицах — число строк, наи- 
большие и наименьшие значения в колонках. Систем- 
ный каталог поддерживает данные, которые админис- 
тратор может использовать при восстановлении систе- 
мы. 

Реляционные СУБД могут также использовать эту 
информацию для оптимизации ЗрЬ-запросов. Однако 
эти данные поддерживаются не всеми СУБД. Приме- 
ром может послужить, в частности, Огасіе — одна из 
реляционных СУБД, не имеющих средств хранения в 
каталоге статистической информации. 

Управление транзакциями 

СУБД должна поддерживать целостность базы дан- 
ных при выполнении транзакций. 5(ЗЬ~серверы осо- 
бенно мощны в реализации этого требования. Транз- 
акция — это набор команд работы с базой данных, ко- 
торый выполняется каждый раз при решении опреде- 
ленной задачи. Обычно при выполнении транзакции 
обновляется несколько таблиц и индексов, связанных с 
этими таблицами. 
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Для того, чтобы гарантировать синхронизацию 
обновления и целостность данных, в серверах обычно 
используют принцип “все или ничего”, то есть либо 
вносят все обновления транзакции в базу данных, либо 
не вносят ни одного из них. Это происходит 
следующим образом. Обработка транзакции 
начинается после получения команды “начало 
транзакции”. Некоторые системы используют спе- 
циальную команду, другие воспринимают в качестве 
неявной команды начало программы. Завершает 
транзакцию команда 8<ЗЬ СоттіІ, она и служит сиг- 
налом серверу базы данных о том, что все полученные 
изменения могут быть внесены в базу данных. Если 
же в процессе обработки транзакции произошел сбой, 
то все изменения транзакции автоматически игнориру- 
ются, а база данных сохраняется в неизменном состоя- 
нии. 

Управление транзакциями включает также такие 
важные элементы как автоматическая блокировка дан- 
ных на время внесения изменений и определение со- 
стояний взаимоблокировки. Блокировка (Ьоскіп^) 
предотвращает одновременное обновление данных не- 
сколькими пользователями. Некоторые серверы требу- 
ют явного указания операторов блокировки в тексте 
транзакции, но автоматическая блокировка предпочти- 
тельнее. Блокировать (в зависимости от типа системы) 
можно отдельные записи, страницы или только всю 
таблицу. Страницы представляют собой физические 
блоки, размеры которых варьируются от 1 до 4 Кбайт 
и включают несколько записей. Блокировка на уровне 
записи обеспечивает наивысший уровень параллелиз- 
ма. Блокировка на уровне таблицы позволяет в каж- 
дый момент времени обновлять таблицу только одному 
пользователю. Блокировка на уровне страницы нахо- 
дится где-то посередине. Большинство серверов реали- 
зуют блокировку на уровне записи или страницы. 
Единственной реляционной СУБД, которая предостав- 
ляет возможности для динамического выбора уровня 
блокировки между уровнем записи и уровнем таблицы 
является СУБД ІпГогтіх-ОпІіпе. 

Серверы базы данных должны автоматически опре- 
делять состояние взаимоблокировки (беабіоск). Это 
состояние возникает тогда, когда программа А читает 
запись, которая заблокирована программой В, а прог- 
рамма В читает другую запись, которая заблокирована 
программой А. Каждая из программ в этом случае бу- 
дет ожидать завершения другой. Следовательно, обе 
программы окажутся в состоянии взаимного ожидания, 
которое и называется взаимоблокировкой. Сервер базы 
данных должен выявлять подобные состояния и авто- 
матически прерывать выполнение одной из транзак- 
ций, выводя тем самым другую из вечного ожидания. 
Прерванная транзакция после исключения возможнос- 
ти ее блокировки будет выполнена сначала. В некото- 
рых системах отработка подобных ситуаций выполня- 
ется автоматически, в других требуется определенный 
опыт программирования, поскольку при определении 
состояния взаимной блокировки программы будут вы- 
полнены повторно сначала. 


Восстановление базы данных 

Возможности восстановления базы данных являются 
критическим фактором в выборе сервера. При возник- 
новении сбоя в системе или порчи информации на 
диске данные, не записанные физически в резервной 
копии базы данных, могут быть восстановлены из сис- 
темных буферов. А чтобы гарантировать, что ни одно 
из этих данных не пропадет, сервер базы данных дол- 
жен поддерживать специальный текущий файл регист- 
рации всех прошедших транзакций. 

В случае выхода из строя системы или жесткого 
диска, обычная процедура состоит в том, чтобы пере- 
записать базу данных с резервной копии. Но в таком 
случае теряются все обновления, которые прошли с 
момента создания резервного файла вплоть до выхода 
из строя жесткого диска. Сервер базы данных должен 
поэтому иметь специальные утилиты, позволяющие 
считывать текущий файл регистрации транзакций и 
восстанавливать их. Такие процедуры восстановления 
носят название “Коіі Ропѵагб“. Сервер ІВМ ОаІаЬазе 
Мапа^ег 08/2 Ехіепбед Еёіііоп на сегодня единствен- 
ный из пакетов, не имеющий подобной процедуры. 

Некоторые серверы баз данных имеют так называе- 
мый “терпимый к сбоям" режим работы (Іаиіі-юіегапі 
ргосеззіп^), сущность которого состоит в следующем. 
Две системы ведут одновременно две копии одних и 
тех же данных. Если одна из систем выходит из строя, 
то другая продолжает работать, сохраняя целостность 
базы данных. Метод крайне дорогостоящий, но в неко- 
торых приложениях (работающих в реальном време- 
ни) без подобных издержек просто не обойтись. 

Оба названных метода поддерживают программные 
продукты Іп^гезз, 5(}Ь Зегѵег, 8<ЗЬ Вазе и ІпГогтіх-Оп- 
Ііпе. 

Целостность данных 

СУБД должны обеспечивать выполнение правил це- 
лостности или взаимной согласованности данных, 
включая целостность объектов, ссылок и реализацию 
правил, вводимых пользователем. 

Целостность объектов предполагает уникальность 
каждой записи в таблице. Чтобы обеспечить целост- 
ность объектов, в таблице выделяется поле (или груп- 
па полей), значение которого всегда должно быть оп- 
ределено, значение этого поля (полей) однозначно оп- 
ределяет запись и называется ключом. 

Целостность ссылок гарантирует согласованность 
значений полей в нескольких реляционных таблицах. 
Непосредственно (с помощью оператора языка 8(}Ь 
СКЕАТЕ ТАВЬЕ наподобие используемого в ЦВ2) 
поддерживает целостность ссылок сервер фирмы ІВМ 
ЦаіаЬазе Мапа^ег 08/2 Ехіепбеб ЕбИіоп. Этот ва- 
риант наиболее предпочтителен. Сервер ХЦВ фирмы 
ХОВ 8уз(ешз позволяет пользователям определять вза- 
имосвязь ссылок с помощью команды языка 8(}Ь 
АЬТЕКТАВЬЕ. В 8(}Ь 8егѵег фирмы 8уЬазе и СУБД 
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СЕРВЕРЫ БАЗ ДАННЫХ 


Іп^гез используются т.н. триггеры. Триггеры представ- 
ляют собой процедуры, которые автоматически выпол- 
няются перед каждым обновлением базы данных. Ад- 
министратор базы данных может выполнять триггеры 
на сервере базы данных. 

Взаимодействие серверов 

На больших предприятиях может возникнуть необ- 
ходимость в организации взаимодействия между нес- 
колькими серверами или их совместной работы с боль- 
шими и мини-ЭВМ. Соединяя системы вместе, следует 
выбрать одну из альтернатив: либо организовать прос- 
тейший вариант обмена данными между компьютера- 
ми и выбрать способ загрузки данных в главную ЭВМ, 
либо пытаться эмулировать работу распределенной ба- 
зы данных. С точки зрения пользователя в распреде- 
ленных базах данных несколько серверов работают 
“прозрачно", т.е. как один очень большой сервер. У 
администратора же базы данных появляется возмож- 
ность более равномерно распределять загрузку мощ- 
ностей, в то время как вся информация остается дос- 
тупной пользователям, работающим на нескольких ра- 
бочих станциях. Некоторые СУБД позволяют выпол- 
нять только поиск информации в таких системах, дру- 
гие поддерживают полное распределенное обновление. 
Примером реляционной СУБД, полностью поддержи- 
вающей распределенную базу данных, может служить 
сервер ѴІА/Г)КЕ. 

Другой аспект взаимодействия — это взаимодейст- 
вие программного обеспечения, обеспечивающее прог- 
раммам доступ к удаленным базам данных на основе 
модели реег-іо.-реег. Такие программы обычно исполь- 
зуют специальный протокол АРРС (Аёѵапсеб- 
рго8гатт-1о-рго8гатт-соттипіса1іоп) фирмы ІВМ. 
Используя АРРС, программы могут выполнять боль- 
шую часть своей работы в локальной сети, сохраняя 
средства доступа к ограниченным наборам данных на 
больших или мини-ЭВМ. Этот сценарий обычно реа- 
лизуется, когда сетевые прикладные программы нуж- 
даются в обновлении или поиске записей, хранящихся 
в базе данных большой ЭВМ. Протокол АРРС исполь- 
зуется, например, в пакете 8<5ІЛеІ, который фирма 
Сиріа ТесЬпоІогу разработала для обеспечения сов- 
местимости своего сервера Вазе с СУБД ЭВ2 

фирмы ІВМ. МісгозоМ также с помощью АРРС 
недавно внедрила “связку" для своего сервера базы 
данных 5<}Ь Бегѵег и СУБД ОВ2. 

Управление ресурсами 

У серверов баз данных очень широк диапазон ре- 
сурсов, которые они потребляют, и требований по их 
управлению. Программы серверов баз данных, ориен- 
тированных на большие и мини-ЭВМ, не соответству- 
ют продуктам для ПЭВМ. Серверы, адаптированные с 
больших ЭВМ, могут иметь также поддержку файло- 


вых форматов для ПЭВМ и адекватные возможности 
импорта/экспорта файлов ПЭВМ. Ограничения по 
требованиям к памяти на каждого пользователя у сер- 
веров могут варьироваться от 30 до 500 Кбайт, при 
наличии внешних систем требования могут быть еще 
более широкими. 

Серверы баз данных используют разные форматы 
хранения данных: некоторые из них хранят записи 
произвольной длины, другие — только фиксированной 
длины. Это ведет к большим различиям в требованиях 
к дисковой памяти. Одни серверы автоматически мо- 
гут вновь использовать пространство памяти, занятое 
удаленными записями, другие могут требовать для 
этого выполнения специальных утилит. 

Наиболее совершенные серверы имеют специальные 
утилиты настройки и мониторинга базы данных, поз- 
воляющие оптимизировать производительность работы. 

Серверы могут также поддерживать команды языка 
СКАЫТ и КЕѴОКЕ, которые обеспечивают без- 
опасность базы данных. 

Для эффективной работы с серверами баз данных, в 
силу их достаточно высокой сложности, требуются ад- 
министраторы, хорошо ориентирующиеся в вопросах 
управления данными. Поэтому вопросы обучения и 
подготовки персонала играют здесь далеко не послед- 
нюю роль. 

Поддержка внешних 
прикладных программ 

Серверы баз данных рассчитаны на поддержку 
большого количества различных типов приложений, и 
разработчики нуждаются в инструментальных средст- 
вах для их использования. Поэтому следует особо ос- 
тановиться на прикладных разработках и инструмен- 
тальных средствах, появляющихся на рынке вместе с 
серверами. 

В зависимости от своих прикладных задач, пользо- 
ватели могут нуждаться в различных типах инстру- 
ментальных средств для реализации интерфейса с ба- 
зой данных: объектно-ориентированные средства, 

электронные таблицы, текстовые процессоры, графи- 
ческие пакеты, настольные издательства и другие. 
Пользователю могут быть также необходимы специ- 
альные инструментальные средства, которые нужны 
при разработке сложных программ, требующих приме- 
нения экспертных систем или других программ искус- 
ственного интеллекта. 

Организация пользователя может уже иметь боль- 
шой опыт работы с однопользовательскими СУБД, та- 
кими как 6ВА5Е, ОаІаЕазе, Рагабох, Кеѵеіаііоп или 
совместимыми с (1ВА5Е, так называемыми “клонами", 
6ВХЦ Сііррег или РохЬазе. Если пользователь заинте- 
ресован в сохранении своих затрат на эти продукты, 
необходимо выбрать сервер, который поддерживает 
данную СУБД. Необходимо также проанализировать 
вопросы переносимости и производительности. У та- 
ких продуктов как Рагабох (зеі-огіепіеб — ориентиро- 
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ванных на группы записей), возможно, в среде 
сервера базы данных сохранится высокая про- 
изводительность. В то же время, у продуктов, 
подобных 6ВАЗЕ (гесогсі-аі-а-ііте — ориенти- 
рованных на отдельные записи) характе- 
ристики производительности могут ухудшить- 
ся. 

В настоящее время разрабатывается много 
новых внешних пакетов, имеющих развитый 
графический интерфейс. Повышение 
производительности программирования в них 
достигается за счет использования объектно- 
ориентированной техники и языка 8(}Ь для 
увеличения продуктивности программирования 
в многооконной среде. Программные продукты 
ОЪіесІ/1, Арріісаііоп Мапагег, Ассезз 5(}Ь и 
5(}Ь \Ѵіпс1о\ѵ5 открывают возможности 
разработки оконных приложений для широкого 
круга 5(}Ь-серверов баз данных. 

Л. Проничева 


По материалам: 
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В первый день выставки СотЗех 
фирма Арріе произвела большой 
фурор, продемонстрировав новые 
серии рабочих станций ОиаОга 700 и 
900, новое поколение портативных 
машин и новый Мае Сіаззіс II. 

Для поддержки новых машин бы- 
ла выпущена следующая версия 
ОС — ѵ.7.01. Она требует 2 Мбайта 
ОЗУ и жесткий диск. Фирма заяв- 
ляет, что новая версия — это не 
замена Зузіеш 7.0, а просто ее 
модификация- для новых машин. 

Настольная станция ()иасіга 700 
выпускается в четырех конфи- 
гурациях — одна только с флоппи- 
диском, остальные с винчестерами 
разной емкости. Ииасіга 900 в 
корпусе типа “Іоиег“ также имеет 
одну бездисковую конфигурацию и 


две дисковых. Цены на станции ле- 
жат в диапазоне 3,499-9,199 дол- 
ларов. 

Обе системы выполнены на про- 
цессоре 68040, работают втрое быст- 
рее Мае Шх, имеют улучшенный 
цветной монитор, поддержку ЕИіег- 
пеі и новую технологию контролле- 
ров диска ЗС5І/!ѴиЬи$. Кроме этого, 
напольная ОиаЗга 900 может иметь 
до 64 Мбайт оперативной памяти, 
дополнительные жесткие диски или 
другие устройства, подключаемые к 
интерфейсу 5СЗІ. 

Пользователи МасіШозЬ Псх и ІІсі 
могут купить небольшую логическую 
схему, которая монтируется на плате 
и превращает их компьютер в стан- 
цию (}иас1га 700. Каждая такая пла- 
та имеет 4 Мбайт оперативной памя- 


ти и 512 Кбайт памяти с батарейкой. 

Новые портативные машины — 
РоѵѵегЬоок 100, 140 и 170 — постав- 
ляются с 2 Мбайтами ОЗУ (расши- 
ряется до 8 Мбайт) и 20- либо 40- 
мегабайтным жестким диском. Цена 
находится в диапазоне от 2,299 до 
4,599 долларов. 

Новый Мае Сіаззіс II превосходит 
старый Сіаззіс в производительности 
и поддержке виртуальной памяти 
благодаря использованию процессора 
68030 с тактовой частотой 16 МГц, 
который вдвое быстрее использовав- 
шегося ранее. Еще одной добавкой к 
Сіаззіс является возможность ввода 
звукового сигнала. 

Мен чЬуІеі Мен і І^еіѵюгк, 21 
ОсІоЬег 1991 
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МУЛЬТИМЕДИА — СИНТЕЗ ТРЕХ СТИХИЙ 



Это заключительная часть статьи 
по системам мультимедиа 
(см. КомпьютерПресс №№ 7,8' 91), 
посвященная перспективам этой 
технологии в нашей стране. 


Мультимедиа - 
синтез трех стихий 


А что у нас? 

Теперь, ознакомившись с положением дел в области 
мультимедиа за рубежом, вернемся домой и оглянемся 
вокруг. Мы увидим, что системы мультимедиа, этот 
качественно новый инструмент познания, обучения, 
общения, которым уже 4 года пользуются школьники 
Англии, который быстро внедряется во все сферы дея- 
тельности и в быт в цивилизованном мире, — у нас 
остается практически неизвестным, по каким-то непо- 
нятным причинам выпав из поля зрения и средств 
массовой информации, и разнообразных ведомств. Ве- 
домства занимаются компьютеризацией школ, пытаясь 
оснащать их — в 1991 году! — устаревшими еще до 
рождения КУВТ-86 и Корветами, способными, в силу 
своей ненадежности и “недружественности“, привить 
лишь отвращение и страх перед компьютерами. Меж- 
ду тем в мире уже выросло “информатизированное 11 
поколение, для которого сети общего пользования, 
системы типа телетекста и видеоданных, электронная 
почта и компьютеры стали естественным, непремен- 
ным атрибутом окружающей жизни как в профессио- 
нальной деятельности, так и дома. Это не кажется 
страшным, если рассматривать отдельно взятого наше- 
го человека: если “окунуть* 1 его в эту среду, он, быст- 
рее ли, медленнее ли, перестроит стиль мышления, 
научится управляться с этими информационными инс- 


трументами (для ребенка же вообще не будет проб- 
лем), однако в масштабах страны мы видим качест- 
венное отставание всего общества, всех его институ- 
тов, и это становится непоправимым. Появление и по- 
всеместное внедрение систем мультимедиа увеличива- 
ет скорость, с которой уходит от нас цивилизованный 
мир. 

Попробуем оценить перспективы, которые могут 
ожидать мультимедиа в нашей стране. Для этого по- 
смотрим, как обстояли дела в последние годы с вне- 
дрением других информационных технологий. Сразу 
оговорюсь, что все изложенное ниже — личные 
измышления автора, основанные, однако, на более чем 
пятнадцатилетием опыте барахтанья в неспешном по- 
токе развития отечественной вычислительной техники. 
Безусловно, постоянное сопоставление состояния дел 
“у нас“ и “у них** не может не породить некоторого 
комплекса вечного несоответствия мировому уровню, 
опаздывания, повторного изобретения давно изобре- 
тенного, порой ощущения полной ненужности и бес- 
смысленности всех усилий. Утешала и поддерживала 
лишь аналогия с еще одной областью, поневоле близ- 
кой — стоматологией, отставшей, пожалуй, еще 
больше и безнадежней. Тем не менее, осознавая это 
отставание, наши стоматологи (слава богу!) продол- 
жали сверлить, пилить, лепить, придерживая 
заветный несточенный бор или щепотку цемента, 
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привезенную кем-нибудь из-за бугра, для особо 
доверенных клиентов. 

Грустная история 

Самый све$ий пример — это история отечествен- 
ных персональных компьютеров. Большая ее часть 
происходила уже после объявления перестройки и 
ускорения, и сначала казалось, что ну уж теперь-то!.. 
По рукам ходили какие-то отксеренные аналитические 
записки и докладные из высоких сфер: массовые за- 
купки комплектующих и периферии, закупки заводов, 
совместные производства... И что же? Истинная ком- 
пьютеризация страны происходит лишь сейчас, с по- 
мощью бартерных закупок и сборочных СП, по совсем 
не персональным ценам и не благодаря, а вопреки 
усилиям министерств, которые смогли в результате 
многолетних и дорогостоящих усилий наводнить кла- 
довки, пространства на шкафах и под столами в тыся- 
чах учреждений и школ по всей стране пирамидами 
грязно-серо-черных неработающих, полуработающих, 
несовсемработающих — зато “чисто самодельных" 
Электроник, ДВК, Корветов, УКНЦ, Агатов и т.п. Как 
будто об этой “технике" писал анонимный адресант 
Генри Баскервиля: “Если вам дороги ваш рассудок и 
ваша жизнь, держитесь подальше от торфяных бо- 
лот..." 

Подобное положение и с внедрением сетей: мини- 
стерствам связи европейских стран хватило в конце 
70-х годов по 3-4 года от первоначального проекта до 
введения в полномасштабную эксплуатацию обще- 
национальных сетей общего пользования. Появившие- 
ся примерно тогда же, не без оглядки на Запад, про- 
екты ОГСПД и Академсети, записанные во множество 
планов и постановлений и разрабатывавшиеся целыми 
институтами, так где-то и растворились в процессе ре- 
ализации. Тут, безусловно, значительная часть про- 
блемы заключалась в отсутствии каналов связи, но это 
лишь подтверждает закономерность: нам при наличии 
супер-министерства связи (и еще МПСС в недавнем 
прошлом) осталось немного подождать, пока какое- 
нибудь из СП не обеспечит Москву, а потом и страну 
качественной сетью скоростных связных трактов 
(такие проекты уже есть), другое поставит узлы и не- 
обходимый софтвер — и сеть готова. Сейчас такой 
процесс быстро проходит на территории бывшей 
ГДР — и она включается в мировую “инфосферу". 

Пожалуй, еще более показательна ситуация с ло- 
кальными сетями: для них не нужны ни дорогие 
тракты — достаточно мотка дешевого кабеля или даже 
скрученной пары проводов, ни высокая электронная 
технология, ни даже глубокие научные разработки: 
стандарты и протоколы давно опубликованы, проком- 
ментированы, описаны- методы их реализации и воз- 
никающие проблемы; казалось бы, есть все, чтобы 
организовать выпуск несложных сетевых контролле- 
ров, реализующих протоколы нижних уровней (для 
разных типов ЭВМ), приложить программные модули 
для верхних — и получить недорогую локальную сеть 


массового применения. Однако на практике в течение 
многих лет многие умельцы (без иронии!) во множе- 
стве контор параллельно создавали уникальные невос- 
производимые локальные сети из подручных 
средств — вплоть до крейтов КАМАК и шкафообраз- 
ных МПД ЕС ЭВМ. Это приводило к колоссальным 
затратам сил, средств, причем часто впустую: очень 
многие разработки заглохли на разных этапах реали- 
зации в связи с непосильностью задачи, слишком 
большим временем разработки, отсутствием програм- 
много обеспечения или просто уходом основного 
умельца. Массовое же внедрение локальных сетей 
происходит лишь после снятия эмбарго, путем поста- 
вок из-за рубежа готовых комплектов сетей. 

Подобная ситуация может повториться и в разра- 
ботке средств мультимедиа. В связи с тем, что прак- 
тика уже требует внедрения каких-то элементов муль- 
тимедиа, а отечественная промышленность пока ни- 
чего предложить не может, вполне вероятна разра- 
ботка и изготовление “на коленке*' единичных плат 
под конкретные применения. 

Итак, мы видим, что опыт развития вычислитель- 
ной техники в нашей стране на протяжении 80-х го- 
дов показывает, что большинство программ провали^ 
ваются или реализуются недопустимо медленно при 
“изоляционистском** подходе к их выполнению. 
Исходя из этой закономерности, а также задавшись 
целью обеспечить возможность более быстрого внедре- 
ния мультимедиа и других новых технологий в СССР, 
а не многолетнее спокойное финансирование исследо- 
ваний их развития за рубежом, необходимо макси- 
мально ориентироваться на всевозможные совместные 
формы исследований, разработки и производства. 

Ближайшие перспективы 

Рассмотрим различные стороны деятельности по 
исследованию и развитию систем мультимедиа. 

1. Работы по отдельным теоретическим аспектам и 
отдельным компонентам мультимедиа. Они уже 
сравнительно давно проводятся в стране — это такие 
направления, как технология гипертекста, базы дан- 
ных, обработка изображений, звука, комплексные 
инструментальные системы, графические и анимаци- 
онные средства. Существуют некоторые наработки и 
опыт работы в этих областях. Однако они разроз- 
нены, их приложение к “истинным** системам муль- 
тимедиа, интеграция в единую систему мультимедиа 
затруднены как отсутствием адекватных технических 
средств, так и недостаточной координацией этих 
исследований именно под углом зрения мультимедиа. 
Тем не менее деятельность по разработке техни- 
ческих и программных средств синхронизации, за- 
хвата и обработки изображения, работы со звуко- 
выми данными, стыковки компьютера с аналоговыми 
устройствами весьма перспективна в наших усло- 
виях. Спрос на подобные средства уже велик, отече- 
ственный рынок же почти пуст. Причем на доступ- 
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ной элементной базе наши разработчики и програм- 
мисты вполне могут создавать продукты, не уступа- 
ющие зарубежным аналогам. Один из примеров — 
разработанный малым предприятием “Софт-Хард 
Технология" цветной видеодигитайзер для ІВМ-со- 
вместимых компьютеров, работающий в реальном 
времени и обеспечивающий разрешение 832x600 
пикселов при 19 битах под цвет пиксела. Плата ви- 
деодигитайзера поставляется с пакетом программной 
поддержки, обеспечивающим работу с ней из языков 
Си и Паскаль. 

2. Разработка и реализация алгоритмов сжатия 
информации. Основной прогресс в развитии цифро- 
вых систем мультимедиа в последнее время обеспе- 
чен развитием и реализацией алгоритмов сжатия. В 
части разработки алгоритмов дела в СССР могут 
оказаться неплохи — методы сжатия изображений 
наверняка применялись в космической и военной 
технике и сейчас, в рамках конверсии, они могут 
быть приоткрыты и запатентованы; кроме того, ко- 
дировщики и математики могут разработать новые 
алгоритмы или заняться улучшением, дальнейшим 
усовершенствованием публикуемых алгоритмов 1РЕС 
и МРЕС. Проблемы возникнут, однако, при реализа- 
ции разработанных алгоритмов. Здесь сильно ме- 
шают отсутствие необходимой технологии и инерци- 
онность промышленности. Нам не под силу, подобно 
маленькой фирме С-СиЬе Місгозузіега, разработать 
СБИС-микросхему, реализующую алгоритм сжатия и 
сравнимую по сложности с 80386, наладить ее про- 
мышленный выпуск, разработать и также запустить 
в производство плату расширения на основе этой 
микросхемы, “одеть" все это софтвером и в ре- 
зультате менее чем за год (!) получить общедоступ- 
ный коммерческий продукт, который любой пользо- 
ватель может установить на своем компьютере. 
Можно рассчитывать только на не столь эффектив- 
ные программные реализации, в лучшем случае — 
малосерийные платы на дискретных элементах. 

Если думать о перспективе выпуска плат мультиме- 
диа у нас в стране, то возможен вариант частичной 
реализации алгоритма сжатия на кристалле, чтобы 
достичь уровня сложности схемы, посильной для на- 
шей технологии, остальная часть алгоритма реализу- 
ется программно, возможно, с занесением в КОМ. 
Другой путь — использование КІ5С-процессоров 
(которых, впрочем, тоже пока нет — но они по 
уровню сложности доступны нашей МЭП-техноло- 
гии). Лучший, быстрейший путь — это некая форма 
совместной деятельности с цивилизованной стра- 
ной — от закупки чужих чипов сжатия (их цена 
сейчас порядка 50-200 долларов) и производства на 
их основе собственных плат до патентования своих 
алгоритмов и выпуска реализующих их чипов за ру- 
бежом. 

3. Выбор политики в области технических средств. 

На первом этапе, этапе исследований и опытного 
внедрения мультимедиа, единственное приемлемое 
решение — закупка плат и устройств мультимедиа 


за рубежом. Здесь приходится задуматься над выбо- 
ром: какого стандарта мультимедиа следует 

придерживаться. 

Для начала приходится с сожалением признать, что 
в ближайшей перспективе выбор массового компью- 
тера практически сделан за нас — это линия ІВМ 
РС. Далее, среди многочисленных систем мультиме- 
диа для машин этой линии на начало 1991 года на- 
ибольшего внимания заслуживали два варианта: ДѴІ 
и новые продукты 11ѴС. Однако сейчас все большее 
количество фирм объявляет о своей поддержке алго- 
ритмов 1РЕС и МРЕС. Наиболее желателен вариант 
приобретения 3-4 вариантов плат мультимедиа, а 
испытания проводить при реализации пунктов 4 и 5. 
В дальнейшем необходимо постоянно следить за ми- 
ровым рынком мультимедиа, за технической полити- 
кой ведущих фирм; при появлении перспективных 
(или общепризнанных) систем следует обеспечивать 
их закупку или получение на испытания. 
Тщательный, продуманный выбор между существу- 
ющими в мире стандартами и направлениями очень 
важен, чтобы не совершить ошибки, подобной вы- 
бору системы 5ЕСАМ в телевидении, не уйти в ту- 
пиковую ветвь, не создать еще один информацион- 
ный занавес от цивилизованного- мира и иметь воз- 
можность на выбранных технических средствах со- 
здавать продукты, имеющие спрос на мировом 
рынке. 

Не следует, однако, путать разные задачи. Сказан- 
ное выше относится главным образом к “массовому" 
применению мультимедиа — в образовании и учреж- 
денческой деятельности. В то же время авторские 
программно-аппаратные комплексы для разработки 
СД-К.ОМ — электронных книг, руководств, других 
продуктов гипермедиа чаще создаются на базе Мас- 
іп(озН. Хорош этот компьютер и при подготовке, 
производстве и использовании интерактивных виде- 
одисков благодаря стекам Нурегсагб, позволяющим 
хранить ссылки на конкретные кадры аналогового 
видеоустройства, гибкой системе управления презен- 
тацией пакета Оігесіог, а также настольной системе 
записи и воспроизведения таких дисков, управляемой 
с МасіпІозЬ. Сейчас — наконец-то! — фирма Арріе 
выходит на наш рынок. Будем надеяться, что ей уда- 
стся нарушить сложившееся в стране необъяснимое, 
иррациональное засилье компьютеров линии ІВМ во 
всех сферах применения — даже в тех, где они зна- 
чительно проигрывают своим конкурентам, и что 
мультимедиа-системы на базе МасіпіозН станут 
одним из основных направлений этого наступления 
Арріе. 

Для систем настольных видеостудий может больше 
подойти Атіда либо, опять-таки. Мае. Для более 
сложных применений, с жесткими временными 
требованиями и большим’ объемом вычислений, си- 
стему придется создавать на базе мощных рабочих 
станций типа $ип или К-6000 ІВМ. 

4. Разработка инструментальных средств мультимедиа, 
авторских систем. Уже отмечалось, что в этой обла- 
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сти требуются усилия разработчиков. Однако они мо- 
гут быть успешными, конкурентоспособными лишь в 
случае быстрого приобретения новых технических 
средств, для которых еще не сложился круг привыч- 
ного для пользователя инструментального софтвера; 
здесь можно пойти на прямой контакт с фирмой — 
производителем технических средств. Другая воз- 
можная “ниша“ — открыть какую-то новую сферу 
применения имеющихся технических, средств и со- 
здать специализированную авторскую систему для 
этой сферы. 

5. Разработка конечных продуктов мультимедиа раз- 
ных типов, а также методик их проектирования и 
изготовления. Это совершенно новый вид деятельно- 
сти, сочетающий черты программирования, разра- 
ботки игр, производства фильмов и др.; в СССР пока 
практически нет специалистов в этой области. По- 
мимо сложных задач интерактивного программиро- 
вания, управления информацией, навигации, возни- 
кают также проблемы: создания сценария, производ- 
ства видео-, фото- и аудио-материалов. Как правило, 
необходимо участие специалистов в предметной 
области, к которой относится создаваемый продукт. 
Некоторый опыт такой работы накоплен в Третья- 
ковской галерее. Русском музее, где уже в течение 
ряда лет ведутся работы (совместно с зарубежными 
фирмами) по занесению фондов на интерактивные 
видеодиски. 

Задачи 4 и 5 тесно взаимосвязаны: без опыта произ- 
водства продуктов мультимедиа трудно оценить сла- 
бости существующего авторского софтвера, прочув- 
ствовать тонкие места при работе с данной 
аппаратурой; создаваемую авторскую систему по- 
лезно испытывать и оценивать на разработке кон- 
кретного продукта. С другой стороны, иногда в про- 
цессе разработки большого продукта мультимедиа со- 
здается столько инструментальных и вспомогатель- 
ных программ, что их выпускают на рынок в каче- 
стве самостоятельного продукта. Так, в частности, 
поступила Вгііаппіса ЗоСПѵаге, которая вслед за вы- 
ходом Сотріоп МиІіі-МесЗіа Епсісіораесііа выпустила 
РиЫізЬег СЭ-КОМ Тооікіі. 

Работы по этим двум пунктам должны привести к 
появлению и внедрению первых отечественных про- 
дуктов мультимедиа. Однако здесь возникает серьез- 
ная проблема. 

6. Распространение и применение продуктов муль- 
тимедиа. Это — вопрос, наиболее критичный в 
СССР. Дело в том, что сегодня они просто не могут 
дойти от изготовителя до потребителя. В СССР нет 
ни СЭ-КОМ, ни оптических стираемых дисков, ни 
сменных винчестеров, ни ленточных устройств боль- 
шой емкости, ни скоростных сетей. На дискету 
1.44 Мбайт помещается около 10 секунд видео в 
сжатом формате ЦѴ1; передача такого же количества 
данных через телефонную сеть при очень оптими- 
стической скорости 4800 бод потребует полчаса; вы- 
деленные каналы побыстрее в 2-4 раза. Локальная 
сеть позволит передавать данные мультимедиа лишь 


в пределах одного учреждения. Полувыходы, пер- 
выми приходящие на ум: установка продукта на вин- 
честер пользователя разработчиком с помощью до- 
ставки имеющегося у разработчика внешнего нако- 
пителя с контроллером и подключения его к машине 
пользователя; путешествие разработчика со своим 
компьютером и локальной сетью к пользователю или 
наоборот; перекачка данных мультимедиа на боль- 
шую машину и запись на ее ленты, а затем распро- 
странение этих лент; при этом, однако, у поль- 
зователя также должна быть в досягаемости связка 
ПК — большой компьютер. 

Что касается производства внешних устройств боль- 
шой памяти, то здесь надеяться на нашу промыш- 
ленность, видимо, не приходится: за все годы разви- 
тия ЕС ЭВМ ей (как, впрочем, и болгарской) не 
удалось создать (скопировать) ни одного дискового 
магнитного устройства достаточного качества и на- 
дежности. Изготовление же оптических устройств, 
даже при допущении наших передовых позиций в 
лазерных делах, все равно упрется в больные про- 
блемы точной механики и малообъемной высокочи- 
стой химической технологии. 

Впрочем, я с радостью готов взять свои слова 
обратно, если кто-нибудь меня опровергнет. Так, ко 
мне в последний момент попала очень обнадежива- 
ющая бумага — рекламный листочек МНПП 
“КОМПАКТ" (г. Москва), объявляющий о выпуске 
этим предприятием и А/О “СИНКВЭС" (Таллинн) 
отечественных дисководов СБ-КОМ, полностью соот- 
ветствующих международным стандартам, подключа- 
емых к ІВМ РС, работающих с Місгозоіі СЦ-Ехіеп- 
(іол и даже воспроизводящих аудиодиски. Постара- 
емся получить более подробную информацию об 
этой системе, возможно, испытать ее в действии — 
и о результатах сообщим читателям. 

Приобретение для пользователей дисководов СО- 
КОМ могло бы стать хорошим выходом, но при этом 
придется отсылать подготовленные продукты для ти- 
ражирования за рубеж, что достаточно накладно, 
особенно при малых сериях. Видимо, следует прояв- 
лять активность в направлении организации выпуска 
СО-КОМ дисков в нашей стране; такое производство 
может быть, в частности, организовано на базе 
фирмы “Мелодия", уже выпустившей первые лазер- 
ные аудиодиски. Возможно, какое-нибудь крупное 
издательство проявит интерес к этому очень пер- 
спективному направлению и создаст, например, СП 
по выпуску оптических и СО-КОМ дисков? Напо- 
мним, что рынок таких электронных изданий за ру- 
бежом достигает миллиардных отметок. 

(Здесь я должен извиниться перед читателями за до- 
пущенную мной в КомпьютерПресс 7'91 неточность: 
чистый диск СО-КОМ стоит несколько долларов, а 
чистый видеодиск — порядка 100-200 долларов.) 
Каковы же ближайшие практические перспективы 
разработчика конечных продуктов мультимедиа? Ви- 
димо, сначала придется ориентироваться на хорошо 
оснащенных пользователей, например показательные 
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' “пилотные" школы или учебные центры, или на еди- 
ничные применения типа тренажеров, “информаци- 
онных киосков" в музеях и т.п. Кроме того, следует 
обеспечить такие конфигурации закупаемых учебных 
комплексов, которые в будущем могли бы легко быть 
расширены в станции мультимедиа — установкой 
дополнительных плат или подключением внешних 
устройств либо даже просто добавлением программ. 

7. Наконец, главное в научном плане: исследование 
мультимедиа как составной части информационных 
технологий будущего, в комплексе всех связанных 
проблем; именно здесь существуют наилучшие воз- 
можности не копирования зарубежного опыта, а по- 
лучения оригинальных научных результатов, разви- 
тия своей линии в области мультимедиа. Однако для 
этого требуется закупка комплекса технических и 
программных средств для создания стартовых усло- 
вий, соответствующих передовому сегодняшнему 
уровню. 

Практические работы с системами мультимедиа (п.п. 
4,5) затронут предметы “более высокой теории" — 
построения ММ-баз, систем гипертекста и ги- 
перизображений, объектно-ориентированных сред и 
т.п., а также прикладные вопросы отдельных 
“медий": быстрая компьютерная графика и анима- 
ция, настольные видеостудии, компьютер и музыка, 
электронная и видеопочта, что с необходимостью 
приведет к активизации работ в этих крайне инте- 
ресных направлениях. Однако необходимо зани- 
маться и вопросами развития информационных си- 
стем в целом, их положения и роли в современном 
мире и в преобразовании этого мира. Для разработки 
этих фундаментальных вопросов было бы полезно 
отойти от ІВМ РС с их беспорядочно, бессистемно 
наращиваемым нагромождением хардвера и софтвера 
(например: 005, над ним \Ѵіп«1ошз, над АѴіпбоѵз 
ТооІВоок, над ТооІВоок перенесенный с Мае Сиібе, 
над Сиібе собственно продукт), и обратиться к ком- 
пьютеру ЫеХТ, который в наибольшей степени со- 
ответствует требованиям времени, поскольку задумы- 
вался и создавался именно как информационный ин- 
струмент завтрашнего дня, интегрируя последние до- 
стижения и теории, и технологии. 

О координации 

К сожалению, сведения об отечественных работах 
по мультимедиа получить труднее, чем о зарубежных. 
В общедоступной компьютерной периодике практичес- 
ки ничего не публикуется, специального издания нет. 
Поэтому пока исследователи в этой области довольно 
разобщены. 

Большие надежды мы возлагали на межотраслевую 
конференцию “Оптические дисковые информацион- 
ные системы", которую должны были провести в 
октябре 1991 года Минрадиопром и НИИ бытовой 
радиоэлектронной аппаратуры (г. Львов) — с очень 
интересным кругом рассматриваемых проблем. Она 
могла бы послужить началом объединения усилий 


разработчиков мультимедиа в СССР. Однако — 
увы — перенесена на неопределенный срок. 

Сведения о ряде конкретных отечественных разра- 
боток, дошедшие в виде слухов и частных сообщений, 
нуждаются в проверке, поэтому о них — в следующих 
номерах. 

В настоящее время предпринимаются усилия по со- 
зданию Центра мультимедиа. Задачами Центра, поми- 
мо проведения собственных исследований в различных 
областях мультимедиа, являлись бы координация 
работ с другими организациями в области мультиме- 
диа, вовлечение их в работы по перечисленным выше 
пунктам, пропаганда технологии мультимедиа, обуче- 
ние и консультации по использованию имеющихся си- 
стем, инициирование исследований во вновь появля- 
ющихся перспективных направлениях. Возможно 
также издание бюллетеня или журнала по мультиме- 
диа и близким тематикам. 

Будем надеяться, что темпы проникновения муль- 
тимедиа в нашу страну увеличатся — и за счет появ- 
ления собственных разработок, и за счет более актив- 
ного выхода на наш рынок зарубежных фирм. Сейчас 
же либо за рубежом считают, что нам пока за глаза 
достаточно конторских ІВМ РС, либо какие-то эле- 
менты мультимедиа находятся под контролем КОКОМ 
как элементы новейших технологий — во всяком слу- 
чае, на проходящие в стране выставки образцы муль- 
тимедиа-продукции почти не попадают. Поэтому пока 
приходится, довольствоваться сведениями из зарубеж- 
ной периодики, пытаться получить понятие о целом 
на основе чьих-то обрывочных впечатлений, иными 
словами “ощупывать хвост слона“, а затем убеждать 
всех, что слон длинный и тонкий как змея — что я и 
постарался сделать в этом обзоре. 

С.Новосельцев 
Сетевой адрес 
пех1@іріап15. іріап. твк. ви 


МісговоГі сделала русский М8-Б08 5.0. Это третий 
русскоязычный продукт, выпущенный фирмой. 

Система, по утверждению разработчиков, работает 
лучше предыдущей версии. В ней используется перера- 
ботанный пользовательский интерфейс, многочислен- 
ные подсказки — все на русском языке. 

Кроме того, система имеет встроенные утилиты вос- 
становления удаленного файла и почти многозадачный 
режим. Существенно улучшена поддержка принтеров, 
не имеющих прошитых русских букв. Система будет 
поддерживать как русский, так и украинский и бело- 
русский языки. 

Продаваться русский М8-И08 будет только в ком- 
плекте с компьютерами. Это политика фирмы, которая 
хочет получить хоть какие-то гарантированные прибы- 
ли на советском рынке. 

А еще у фирмы появился новый дистрибьютор в Ки- 
еве — НПП Гамма, имеющий офис на Крещатике. 

Сейчас 8(еер1ег ІАд. из Москвы в экспериментальном 
порядке (до конца года) продает русскоязычный М8 
\Ѵогкв за рубли — 9500 рублей. 

А ІеѵпЬуІез Л'еит А ІеЫогк, 7 ОсіоЬег 1991 
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Между прочим 


Ѵепіига и РаіпІВгизН: маленькие хитрости 

Графический редактор РаІпІВгиаЬ IV Ріиз позволяет ре- 
шить некоторые проблемы, возникающие при работе с паке- 
том Ѵепіига РиЫІаЬег 2.0. 

При распечатке вентуровской графики (рамки, скруглен- 
ные рамки и эллипсы) с серым фоном на принтерах, эмули- 
рующих Ьааегіеі (проверено на С.ГПЖ ІЛРЗ 10 и на КІС(Ж 
РСІЛ8ЕК 6000), нередко возникают светлые или темные по- 
лосы вместо равномерного тона. Избавиться от этого дефекта 
можно, заменив вентуровскую графику, созданную в редакто- 
ре РаІпІВгиаЬ ГѴ Ріиа с использованием другого способа пред- 
ставления полутонов серого цвета (способа образования раст- 
ра). Суть этих замен и превращений в том, чтобы получитъ 
возможность выбирать сам способ, частоту растра (ЬРІ) и яр- 
кость по своему усмотрению. Для работы, кроме Ѵепіига РиЪ- 
ІізЬег, нужен РаІпІВгиаЬ в двух конфигурациях — на 16 цве- 
тов и черно-белая. 

Подробная последовательность действий такова: 

- создать в “вентуре“ на чистой странице графический 
элемент без фона (или скопировать на чистую страницу 
элемент со сверстанной страницы и выключить фон) ; 

- распечатать страницу с этим графическим элементом в 
файл. При этом в меню “Сервис“/“Параметры принтера" 
должен быть выбран принтер ЬааегІеІ + , ЗООдрі и вывод на 
"имя файла". Получившийся файл печати имеет 
расширение .СОО. 

- скопировать файл печати имя файла .СОО в каталог па- 
кета РаІпІВгиаЬ IV Ріиз и конвертировать этот файл в фор- 
мат .РСХ утилитой НР2РСХ.ЕХЕ. для этого следует ввести 
командную строку: НР2РСХ.ЕХЕ «имя файла .СОО» 

В результате будет создан файл «имя файла .РСХ» (далее 
именуемый картинкой). 

- вызвать цветной РаІпІВгиаЬ и загрузить в него созданную 
картинку. При загрузке файла выбрать “СопѵеП Іо соіог". 

Если окажется, что картинка имеет синий фон, то его 
следует превратить в белый. Для этого надо установить 
первичный цвет (ргішагу соіог) синим, вторичный цвет 
(зесопдагу соіог) белым, и, перемещая рабочее поле по полю 
картинки, дважды нажимать соіог егазег (пятый слева сверху 
инструмент на инструментальной панели). 

- выбрать в меню “Оізріау" опцию "Зоііб соіогз опіу" и 
залить желаемую область на картинке каким-либо цветом. 
Цвета соответствуют полутонам серого по увеличению 
черноты в следующем порядке: 

белый, желтый, светло-голубой, светло-серый, светло- 
зеленый, серо-голубой, светло-фиолетовый, коричневый, 
темно-зеленый, темно-серый, красный, темно-фиолето- 
вый, темно-красный, синий, темно-синий, черный. 


Впрочем, для некоторых цветов разница между соответст- 
вующим им полутонам серого трудно различима. После за- 
ливки нужно сохранить картинку, проверить ее размеры 
("ЕсШ" "СНап(е епііге Ітаде" “5еі ипііз") и покинуть цветной 
РаіпІВгизН; 

- вызвать черно-белый РаіпІВгизН и загрузить в него создан- 
ную цветную картинку. При загрузке картинки выбрать 
“$е( НаШопез" и в появившемся диалоговом окне выбрать 
тип, яркость и частоту растра. 

Опыт подсказывает, что тип растровой сетки (ЬаІПопе 
ранет) “РаІНпя" меньше всего подвержен дефектам при рас- 
печатке. Отпечатанная картинка при использовании этого 
растра напоминает обычную газетную фотографию (для раз- 
решения 300x300 точек на дюйм). Если использовать как 
фон графики, то получается очень похоже на фон обычного 
окна в "вентуре". Тип “ШІІиаесІ" выглядит довольно привле- 
кательно — своим рисунком он напоминает тисненую бумагу, 
обычно более подвержен искажениям при распечатке, чем 
“РаШпв". Тип “ЕпЬапсеб" похож на “ШГГиаед", но рисунок 
его тоньше, а подверженность искажениям еще больше. Типы 
“Вауег" и “Нех Ьауег" очень похожи на фон “вентуровской" 
графики и столь же подвержены искажениям. 

Установка яркости (Ьгі^Ніпезз) равной 128 или немного 
больше дает вполне приличный результат. Установка частоты 
растра (ЬаІІЮпе зсгееп зіге) 75 ЬРІ (Ипе рег іпсЬ —линий на 
дюйм) обычно тоже дает приличный результат. Рост величи- 
ны этого параметра делает рисунок растра тоньше, но и чувс- 
твительнее к искажениям при печати, а градации серого — 
менее различными. Однако изменения этого параметра вли- 
яют только на “Раіііпв"; 

- после того, как цветная картинка желаемым образом кон- 
вертирована в черно-белую, обязательно следует сохранить 
ее и покинуть редактор. В случае выхода без сохранения 
результаты конверсии будут потеряны; 

- теперь у нас есть черно-белая картинка, размеры ее нам из- 
вестны. Остается вновь загрузить Ѵепіиге, создать на месте 
графического окна обычное окно нужного размера и загру- 
зить в него нашу картинку. 

Эта же технология может быть полезна, при использова- 
нии для иллюстрирования издания копий экрана, "захвачен- 
ных" утилитой (гееге.ехе. Если такую копию загрузить в 
Ѵепіиге без предварительной обработки, то одни цвета прев- 
ратятся в черный, другие — в белый, в результате чего часть 
изображения станет неразличимой. Если же конвертировать 
эти цвета в полутона серого, то у Вас получится достаточно 
приличная иллюстрация. 

В. Каминский 
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Компьютерные взломщики все еще правят миром — 

так быть не должно 

Корреспонденты №\№Ьу(ез Джон и Барбара Макмуллен 
сообщают, что американские компьютерные системы все 
еще очень уязвимы для нападения хакеров. Эммануэль 
Голдстейн, издатель 2600 Мадахіпе: ТЬе Наскег Оиапегіу, 
заявил в Нью-Йорке, что “американская общественность 
часто дает себя убаюкать ложному чувству безопасности", 
для которого факты компьютерного взлома не дают ника- 
ких оснований. Он продемонстрировал записи того, как 
голландский хакер взламывал компьютеры армии США, а 
также показал, с какой легкостью можно проникнуть в 
компьютерные системы американских деловых и прави- 
тельственных учреждений. 

Датский взломщик завел фиктивного пользователя под 
именем “Лаіщиаіе" (вице-президент США Бап Оиаіе) и 
затем получил полный контроль над системой. Голдстейн 
сказал, что то, что важным пользователям дают очевидно 
угадываемые пароли типа “КшгаіГ, вызывает серьезную 
тревогу. По его словам, взлом системы не причинил ника- 
кого ущерба. В нескольких случаях физического взлома 
было отмечено использование замха фирмы Зішріех всего 
лишь с 1,085 возможными комбинациями. Многих ни в 
чем не повинных людей винят за то, с какой легкостью от- 
крывается этот замок. 

Голдстейн сделал абсолютно правильное заявление. В 
течении многих лет американская политика в этом вопро- 
се сводилась к “преследованию" и “жестким" приговорам 
в отношение небольшого числа преступников, которые бы- 
ли пойманы, вместо использования элементарных методов 
предотвращения преступлений, которые могли бы оказать- 
ся дешевыми, легкими и эффективными. Причины, по ко- 
торым не сделано то, что нужно, несостоятельны как с мо- 
ральной, так и с финансовой точки зрения. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 24, 1991 

Новые лазеры дают ключ к плоским экранам 

Исследователи в американских университетах Ршчіие и 
Вго\ѵп сообщили, что новые сине-зеленые лазеры могут 
сильно улучшить качество всех плоских дисплеев. Синие 
лазеры используют меньшую длину волны, чем красные. 
Их разработка проводилась на коммерческой основе для 
фирмы ЗМ. По словам исследователей при использовании 
этих лазеров на компакт-дисках и СО-КОМ (ПЗУ на ком- 
пакт-дисках) можно будет поместить в 4 раза больше дан- 
ных. Ключом к созданию синих лазеров стала молекуляр- 
ная лучевая эпитаксия, при которой ученые создают стру- 
ктуры на уровнях одного атома. Устройства, использую- 
щие эту технологию, могут появиться в течение одного 
года. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 24, 1991 

АТ&Т создает канал связи для домашних фирм 

АТ&Т создала АТ&Т Ноше ОГПсе МеРѵогк, первую суб- 
сидируемую корпорациями ассоциацию, поддерживаю- 


щую нужды людей, работающих дома. Чтобы стать чле- 
ном ассоциации, нужно чтобы ваш телефон был заабони- 
рован в АТ&Т. Компания планирует взимать плату после 
одного года работы. Члены ассоциации получают ежеквар- 
тальный журнал, скидки на продукцию и услуги АТ&Т и 
могут рассчитывать на более низкие цены у таких фирм, 
как Рапазопіс, ІІРЗ и др. АТ&Т оценивает число амери- 
канцев, которые работают дома в своих личных фирмах, 
в 11.8 миллиона человек, причем ежегодный прирост со- 
ставляет 10%. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 24, 1991 

Ш5СОѴЕЕ будет телефонной карточкой для 5РКІ1ЧТ 

Идя по стопам АТ&Т, перешедшей на кредитные кар- 
точки, и МСІ, заключившей союз с Ѵіаа, Зргіпі подписала 
соглашение, в результате которого кредитная карточка 
Оізсоѵег фирмы Зеагз станет телефонной карточкой для 
телефонной сети Зргіпі, связывая базы данных, используе- 
мые обоими фирмами. Новая программа, названная Ѵаіие- 
РЬопе, предоставит пользователям Оізсоѵег некоторые 
скидки на звонки по сети Зргіпі, сделанные с помощью 
карточек. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 24, 1991 

МПХГОТОЕ представляет сотовые модемы СОЬС 

Міііідупе, компания, работающая в паре с МіИісош, 
анонсировала два сотовых модема, поддерживающих про- 
токол передачи Сеііиіаг Паіа Ііпк Сопігоі — альтернативу 
МОТ 10 с коррекцией ошибок фирмы Місгосот. Протокол 
Сеііиіаг Иаіа Ііпк относится х риЫіс Оотаіп. СОѴС ис- 
пользуются сетью ѴосІаГопе в Великобритании. Согласно 
протоколу сначала формируются поля данных, а затем они 
передаются в кадрах, в которые добавляется поле синхро- 
низации, поле коррекции ошибок, чередование битов и се- 
лективная повторная передача. Модемы можно будет при- 
обрести в ноябре по цене 795 долларов за штуку. Они ра- 
ботают на скорости 2400 бод. МіНідупе также будет по- 
ставлять фирмам, осуществляющим сотовую связь, обору- 
дование для отслеживания передаваемых данных и другие 
изделия. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 24, 1991 

Следует ждать в скором времени появления дешевых-' 
модемов со скоростью передачи 14,400 бит в секунду <— 
компания РНуІоп объявила, что ими создан набор из трех 
микросхем Ѵ.32ВІЗ, который может осуществлять переда- 
чу как данных, так и факсимильных сообщений с такой 
скоростью, а также на всех более низких скоростях соглас- 
но международным стандартам ССГТТ. Новый набор мик- 
росхем включает в себя все, что нужно для обработки го- 
лосовой почты, регистрации звонков, маршрутизации фак- 
симильных сообщений и идентификации звонящего або- 
нента — даже в компьютере класса Іаріор. Ранние версии 
набора использовались в модемах фирмы Науез. Новые 
схемы стоят всего 50 долларов при оптовых закупках. 

ТНе Теіериііпц Ноіііпе, ОсІоЬег 17, 1991 

Несмотря на катастрофическое положение в области 
прав человека, Китай вызывает растущий интерес со сто- 
роны американских фирм, связанных с телекоммуникаци- 
ей. Недавно фирма Науез, производитель модемов, расши- 
рила свое производство, а Зргіпі объявила о контрактах, 
согласно которым в стране появятся ее служба передачи 
сообщений ТеІелаіІ и службы ЗргіпІМаіІ Х.400. Зргіпі сде- 
лала это объявление одновременно с сообщением о заклю- 
чении аналогичного соглашения с Тайванем. Тем време- 
нем агентство ЮПИ сообщило, что семь человек расстре- 
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лано в Китае за кражу медного кабеля. Государственная 
газета Ье&аІ Оаііу назвала такие кражи “сильно распрост- 
раненными". 

Тке Теіериііпв Ноіііпе, ОсІоЬег 17, 1991 

Семь региональных компаний Веіі хотят, чтобы нало- 
гоплательщики заплатили им от 300 миллионов до 1 мил- 
лиарда долларов, прежде чем они доведут волоконную 
связь до всех уголков страны. Таково заключение Рича 
Тома, президента фирмы Теісотшипісайоп* Зоіийопз Гог 
Атегіса, основанное на результатах исследований, прове- 
денных для компаний Веіі такими фирмами, как Агйшг 
О. ІйіИе и Оаіа Кеаоигсеа. 

Тома заявил, что эти субсидии запрашиваются помимо 
требований Веіі об отмене запрета на участие в предостав- 
лении информационных услуг, и сверх их запросов на за- 
мену используемой около века схемы “нормы прибыли" 
на регулирование потолка цен. Субсидии могли бы 
принять форму налоговых льгот, быстрого списания 
действующего оборудования или прямой выплаты денег. 
Недостаток капиталовложений компаний Веіі в свои сети 


угрожает общей конкурентоспособности США, добавил 
Тома. “Зачем компаниям приобретать новую технологию, 
если МСІ Маіі тащится со своим модемом на 2,400 бод, 
или их модем йа 9,600 все время сваливается на более 
низкую скорость передачи", — сказал он. “Телефонные 
сети являются местными сетями, которыми пользуются 
все, и они находятся в плохом состоянии". Вместо того, 
чтобы их улучшать, добавил он, Веіі вкладывает деньги, 
полученные от абонентов, за рубежом, приобретая иност- 
ранные телефонные компании и концессии на сотовую 
связь, хотя обещают крупные капиталовложения, чтобы 
довести свои услуги до уровня стандартов XXI века. 

Тке ТеІериІіп% Ноіііпе, ОсІоЬег 17, 1991 

Подписка на русскую версию Теіериііпі Ноіііпе 
открылась в сети электронной почты РЕПСОМ. 

Теіериііпв Ноіііпе выходит дважды в неделю (1 выпуск 
объемом 10 Кбайт), редактируется в Атланте (США) 
и Лондоне, и стоит для абонентов Релкома всего 
85 рублей в месяц в отличие от американской версии, 
продающейся за (50. Русская версия Ноіііпе выходит в 
свет через пять часов после появления его за океаном. 


На этой странице помещен бланк заказа на журнал «КомпьютерПресс» 

Вы можете его вырезать и, заполнив, отправить нам по адресу: 

113093, Москва, а/я 37 

Подписка на 1992 г, принимается до 31 января 1992 г. Число экземпляров — без ограничений. 
Стоимость годовой подписки на “КомпьютерПресс" — 57 рублей 60 копеек. 

Деньги следует перечислить на расчетный счет агентства “КомпьютерПресс". 

Наши банковские реквизиты : 

получатель: Автобанк (для зачисления на счет №345708) 
расчетный счет получателя: №161202 

банк получателя: ЦОУ при Госбанке СССР. МФО №299112. 

Бланк заказа и заверенную копию платежного поручения или почтовую квитанцию о переводе денег 
на счет Агентства следует приложить к заказу. 

Без одновременной оплаты подписной стоимости заказ не принимается. 


ЗАКАЗ 

От кого 

Адрес 


(ПОЧТОВЫЙ ИНДЕКС УКАЗЫВАТЬ ОБЯЗАТЕЛЬНО) 

Прошу оформить подписку на журнал КомпьютерПресс на 1992 год 

Подписная плата в сумме перечислена 

платежным поручением (почтовым переводом) № 

от 199 г. 


(Копия платежного документа прилагается) . 








С Прини, 

ИПЛІІ ||*И 


Советско-американское предприятие "Соваминко” 
Рекламно-издательское агентство " КомпьютерПресс ” 


Принимает заказы на журнал " КомпьютерПресс ” и 
производит отправку наложенным платежом. 


Заказ высылается по адресу: 191186, Ленинград, Невский проспект, 28, 

Магазин № 1 ”Дом книги” 


От кого 


Адрес 


(почтовый индекс указывать обязательно) 


Номера выпусков . Количество экземпляров 





А/ При 


Советско-американское предприятие " Соваминко " 
Рекламно-издательское агентство ” КомпьютерПресс " 


Принимает заказы на журнал ” КомпьютерПресс ” и 
КУ производит отправку наложенным платежом. 


Заказ высылается по адресу: 630076, Новосибирск, Красный проспект, 60 
Магазин № 7 "Техническая книга” 

Телефон для справок: 20-05-09 


От кого 


Адрес 


(почтовый индекс указывать обязательно) 


Номера выпусков 


Количество экземпляров 
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Вы устали от монотонной работы с цифрами и документами? Вы думаете, что при общении с 
компьютером необходим посредник-программист? Вы работаете с программными продуктами 
только надежных, всемирно известных фирм? 

Электронная таблица 01ЖТКО РКО 3.0 американской корпорации огіапсі Іпіегпаііопаіпозволит 
Вам общаться с компьютером на «ты» и возьмет на себя всю тяжесть текущей работы. 
Любые бухгалтерские и экономические расчеты, возможность вести всю документацию предпри- 
ятия, встроенная издательская система и сложные отчеты типографского качества, деловая графи- 
ка и даже Электронные слайдофильмы со звуковыми эффектами — завтра Вы не будете мыслить 
свою жизнь без (ДОАТТКО РКО. Спектр технических характеристик ОІАТТКО РКО удивительно 
сочетается с неприхотливостью программы: даже на ІВМ РС/ХТ можно работать в графическом 
режиме, использовать автоувеличение фрагментов таблицы от 25 до 100%, печатать во всех мыс- 
лимых и немыслимых режимах, включая бесконечные графики на непрерывной ленте, подбирать 
оптимальную для глаз палитру красок и формировать содержимое меню. 

Стоимость пакета ОІІАТТКО РКО — 4000 рублей или 495 долларов США. 

Общение с ОІІАТТКО РКО приносит радость — приходите, и мы убедим Вас в этом. 

СП «Интерквадро» Москва, 2-й Новоподмосковный пер., 4. Телефон 150-92-01 
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Фирма КОМП — единственный в стране 
разработчик и производитель 
представленной продукции. 
Обеспечивает немедленную поставку 
и гарантийное обслуживание. 


Телефон: (095 ) 353-68 58 
с 1 1 до 18 часов 




МАКЛИНКЕР УНИВЕРСАЛЬНЫЙ 

автоматическое устройство для прокраса и 
восстановления лент матричных принтеров 
шириной до 24 мм. Обеспечивает 100% 
восстановление красящих свойств, что 
позволяет Вам продлить срок эксплуатации 
одной ленты в 30-50 раз при условии 
своевременного прокраса. В комплект 
поставки входит 1 литр тонера, 
обеспечивающий прокрас 2000 м 13-ти 
миллиметровой ленты. Поставка 
дополнительного тонера по желанию 
заказчика. 


”ВЕСНА-4” 

многофункциональное 
интеллектуальное устройство 
на базе однокристальной 
микроЭВМ — обеспечивает 
мгновенное определение номера 
звонящего абонента, а также 
предлагает пользователю 
множество сервисных удобств, 
вплоть до охранной квартирной 
сигнализации. 

МОДЕМ СОМРЫІУК-С4800 

для ІВМ РС АТ/ХТ, обеспечивает передачу 
информации на отечественных телефонных 
линиях со скоростью не менее 1200 бит/с 
на выделенных линиях — не менее 
4800 бит/с. 




Ке§еагсН сепіге СОМР ІЛЮ. 

109388, Ъ.28, Зіюззеіпауа $1., Мозсоѵѵ, ІІЗЗК. 


